
<!DOCTYPE HTML>
<html lang="zh-hans" >
    <head>
        <meta charset="UTF-8">
        <meta content="text/html; charset=utf-8" http-equiv="Content-Type">
        <title>ES6 · Aivin开发笔记</title>
        <meta http-equiv="X-UA-Compatible" content="IE=edge" />
        <meta name="description" content="">
        <meta name="generator" content="GitBook 3.2.3">
        <meta name="author" content="Aivin">
        
        
    
    <link rel="stylesheet" href="../../gitbook/style.css">

    
            
                
                <link rel="stylesheet" href="../../gitbook/gitbook-plugin-search-plus/search.css">
                
            
                
                <link rel="stylesheet" href="../../gitbook/gitbook-plugin-anchor-navigation-ex/style/plugin.css">
                
            
                
                <link rel="stylesheet" href="../../gitbook/gitbook-plugin-fontsettings/website.css">
                
            
                
                <link rel="stylesheet" href="../../gitbook/gitbook-plugin-tbfed-pagefooter/footer.css">
                
            
                
                <link rel="stylesheet" href="../../gitbook/gitbook-plugin-donate/plugin.css">
                
            
                
                <link rel="stylesheet" href="../../gitbook/gitbook-plugin-local-video/video-js.min.css">
                
            
                
                <link rel="stylesheet" href="../../gitbook/gitbook-plugin-splitter/splitter.css">
                
            
                
                <link rel="stylesheet" href="../../gitbook/gitbook-plugin-highlight/website.css">
                
            
                
                <link rel="stylesheet" href="../../gitbook/gitbook-plugin-theme-comscore/test.css">
                
            
        

    

    
        
        <link rel="stylesheet" href="../../styles/website.css">
        
    

        
    
    
    
    <meta name="HandheldFriendly" content="true"/>
    <meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no">
    <meta name="apple-mobile-web-app-capable" content="yes">
    <meta name="apple-mobile-web-app-status-bar-style" content="black">
    <link rel="apple-touch-icon-precomposed" sizes="152x152" href="../../gitbook/images/apple-touch-icon-precomposed-152.png">
    <link rel="shortcut icon" href="../../gitbook/images/favicon.ico" type="image/x-icon">

    
    <link rel="next" href="mockjs.html" />
    
    
    <link rel="prev" href="CommonJS.html" />
    

    
        <link rel="shortcut icon" href='../../assets/images/favicon.ico' type="image/x-icon">
    
    
        <link rel="bookmark" href='../../assets/images/favicon.ico' type="image/x-icon">
    
    
    

    </head>
    <body>
        
<div class="book">
    <div class="book-summary">
        
            
<div id="book-search-input" role="search">
    <input type="text" placeholder="输入并搜索" />
</div>

            
                <nav role="navigation">
                


<ul class="summary">
    
    

    

    
        
        
    
        <li class="chapter " data-level="1.1" data-path="../../">
            
                <a href="../../">
            
                    
                    个人信息
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.2" data-path="友情链接.html">
            
                <a href="友情链接.html">
            
                    
                    友情链接
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3" data-path="js.html">
            
                <a href="js.html">
            
                    
                    web前端
            
                </a>
            

            
            <ul class="articles">
                
    
        <li class="chapter " data-level="1.3.1" data-path="html5.html">
            
                <a href="html5.html">
            
                    
                    html5
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3.2" data-path="js.html">
            
                <a href="js.html">
            
                    
                    js
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3.3" data-path="css.html">
            
                <a href="css.html">
            
                    
                    css
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3.4" data-path="JSX.html">
            
                <a href="JSX.html">
            
                    
                    JSX
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3.5" data-path="CommonJS.html">
            
                <a href="CommonJS.html">
            
                    
                    CommonJS
            
                </a>
            

            
        </li>
    
        <li class="chapter active" data-level="1.3.6" data-path="ES6.html">
            
                <a href="ES6.html">
            
                    
                    ES6
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3.7" data-path="mockjs.html">
            
                <a href="mockjs.html">
            
                    
                    mockjs
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3.8" data-path="ESLint.html">
            
                <a href="ESLint.html">
            
                    
                    ESLint
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3.9" data-path="alias.html">
            
                <a href="alias.html">
            
                    
                    alias
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3.10" data-path="vueJS.html">
            
                <a href="vueJS.html">
            
                    
                    vueJS
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3.11" data-path="Vuex.html">
            
                <a href="Vuex.html">
            
                    
                    Vuex
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3.12" data-path="vue-router.html">
            
                <a href="vue-router.html">
            
                    
                    vue-router
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3.13" data-path="vue-i18n.html">
            
                <a href="vue-i18n.html">
            
                    
                    vue-i18n
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3.14" data-path="element.html">
            
                <a href="element.html">
            
                    
                    element
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3.15" data-path="iview.html">
            
                <a href="iview.html">
            
                    
                    iview
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3.16" data-path="test.html">
            
                <a href="test.html">
            
                    
                    test
            
                </a>
            

            
        </li>
    

            </ul>
            
        </li>
    

    

    <li class="divider"></li>

    <li>
        <a href="https://www.gitbook.com" target="blank" class="gitbook-link">
            本书使用 GitBook 发布
        </a>
    </li>
</ul>


                </nav>
            
        
    </div>

    <div class="book-body">
        
            <div class="body-inner">
                
                    

<div class="book-header" role="navigation">
    

    <!-- Title -->
    <h1>
        <i class="fa fa-circle-o-notch fa-spin"></i>
        <a href="../.." >ES6</a>
    </h1>
</div>




                    <div class="page-wrapper" tabindex="-1" role="main">
                        <div class="page-inner">
                            
<div class="search-plus" id="book-search-results">
    <div class="search-noresults">
    
                                <section class="normal markdown-section">
                                
                                <div id="anchor-navigation-ex-navbar"><i class="fa fa-navicon"></i><ul><li><span class="title-icon "></span><a href="#es6"><b>1. </b>ES6</a></li><ul><li><span class="title-icon "></span><a href="#ecmascript-&#x548C;-javascript-&#x7684;&#x5173;&#x7CFB;"><b>1.1. </b>ECMAScript &#x548C; JavaScript &#x7684;&#x5173;&#x7CFB;</a></li><ul><li><span class="title-icon "></span><a href="#&#x67E5;&#x770B;&#x5F53;&#x524D;&#x6D4F;&#x89C8;&#x5668;&#x5BF9;es6-&#x7684;&#x652F;&#x6301;&#x7A0B;&#x5EA6;"><b>1.1.1. </b>&#x67E5;&#x770B;&#x5F53;&#x524D;&#x6D4F;&#x89C8;&#x5668;&#x5BF9;ES6 &#x7684;&#x652F;&#x6301;&#x7A0B;&#x5EA6;</a></li></ul><li><span class="title-icon "></span><a href="#&#x53D8;&#x91CF;&#x7684;&#x58F0;&#x660E;"><b>1.2. </b>&#x53D8;&#x91CF;&#x7684;&#x58F0;&#x660E;</a></li><li><span class="title-icon "></span><a href="#let---&#x547D;&#x4EE4;"><b>1.3. </b>let   &#x547D;&#x4EE4;</a></li><li><span class="title-icon "></span><a href="#&#x53D8;&#x91CF;&#x7684;-&#x89E3;&#x6784;&#x8D4B;&#x503C;"><b>1.4. </b>&#x53D8;&#x91CF;&#x7684; &#x89E3;&#x6784;&#x8D4B;&#x503C;</a></li><li><span class="title-icon "></span><a href="#const-&#x547D;&#x4EE4;"><b>1.5. </b>const &#x547D;&#x4EE4;</a></li><li><span class="title-icon "></span><a href="#&#x5B57;&#x7B26;&#x4E32;&#x7684;&#x6269;&#x5C55;"><b>1.6. </b>&#x5B57;&#x7B26;&#x4E32;&#x7684;&#x6269;&#x5C55;</a></li><ul><li><span class="title-icon "></span><a href="#&#x6A21;&#x677F;&#x5B57;&#x7B26;&#x4E32;"><b>1.6.1. </b>&#x6A21;&#x677F;&#x5B57;&#x7B26;&#x4E32;</a></li><li><span class="title-icon "></span><a href="#&#x6807;&#x7B7E;&#x6A21;&#x677F;"><b>1.6.2. </b>&#x6807;&#x7B7E;&#x6A21;&#x677F;</a></li></ul><li><span class="title-icon "></span><a href="#&#x6B63;&#x5219;&#x7684;&#x6269;&#x5C55;"><b>1.7. </b>&#x6B63;&#x5219;&#x7684;&#x6269;&#x5C55;</a></li><ul><li><span class="title-icon "></span><a href="#&#x6784;&#x9020;&#x51FD;&#x6570;&#x53C2;&#x6570;-&#x6709;&#x6539;&#x53D8;"><b>1.7.1. </b>&#x6784;&#x9020;&#x51FD;&#x6570;&#x53C2;&#x6570; &#x6709;&#x6539;&#x53D8;</a></li><li><span class="title-icon "></span><a href="#&#x5B57;&#x7B26;&#x4E32;&#x7684;&#x6B63;&#x5219;&#x65B9;&#x6CD5;"><b>1.7.2. </b>&#x5B57;&#x7B26;&#x4E32;&#x7684;&#x6B63;&#x5219;&#x65B9;&#x6CD5;</a></li><li><span class="title-icon "></span><a href="#u-&#x4FEE;&#x9970;&#x7B26;"><b>1.7.3. </b>u &#x4FEE;&#x9970;&#x7B26;</a></li><li><span class="title-icon "></span><a href="#y-&#x4FEE;&#x9970;&#x7B26;"><b>1.7.4. </b>y &#x4FEE;&#x9970;&#x7B26;</a></li><li><span class="title-icon "></span><a href="#flags-&#x5C5E;&#x6027;"><b>1.7.5. </b>flags &#x5C5E;&#x6027;</a></li></ul><li><span class="title-icon "></span><a href="#&#x6570;&#x503C;&#x7684;&#x6269;&#x5C55;"><b>1.8. </b>&#x6570;&#x503C;&#x7684;&#x6269;&#x5C55;</a></li><ul><li><span class="title-icon "></span><a href="#&#x6570;&#x503C;-&#x65B0;&#x589E;&#x51FD;&#x6570;"><b>1.8.1. </b>&#x6570;&#x503C; &#x65B0;&#x589E;&#x51FD;&#x6570;</a></li><li><span class="title-icon "></span><a href="#&#x6307;&#x6570;&#x8FD0;&#x7B97;&#x7B26;"><b>1.8.2. </b>&#x6307;&#x6570;&#x8FD0;&#x7B97;&#x7B26;</a></li></ul><li><span class="title-icon "></span><a href="#&#x51FD;&#x6570;&#x7684;&#x6269;&#x5C55;"><b>1.9. </b>&#x51FD;&#x6570;&#x7684;&#x6269;&#x5C55;</a></li><ul><li><span class="title-icon "></span><a href="#&#x51FD;&#x6570;&#x53C2;&#x6570;-&#x8BBE;&#x7F6E;&#x9ED8;&#x8BA4;&#x503C;"><b>1.9.1. </b>&#x51FD;&#x6570;&#x53C2;&#x6570; &#x8BBE;&#x7F6E;&#x9ED8;&#x8BA4;&#x503C;</a></li><li><span class="title-icon "></span><a href="#rest-&#x53C2;&#x6570;"><b>1.9.2. </b>rest &#x53C2;&#x6570;</a></li><li><span class="title-icon "></span><a href="#&#x7BAD;&#x5934;&#x51FD;&#x6570;-&#x3001;-lambda-&#x8868;&#x8FBE;&#x5F0F;"><b>1.9.3. </b>&#x7BAD;&#x5934;&#x51FD;&#x6570; &#x3001; Lambda &#x8868;&#x8FBE;&#x5F0F;</a></li><li><span class="title-icon "></span><a href="#&#x53CC;&#x5192;&#x53F7;&#x8FD0;&#x7B97;&#x7B26;"><b>1.9.4. </b>&#x53CC;&#x5192;&#x53F7;&#x8FD0;&#x7B97;&#x7B26;</a></li></ul><li><span class="title-icon "></span><a href="#&#x6570;&#x7EC4;&#x7684;&#x6269;&#x5C55;"><b>1.10. </b>&#x6570;&#x7EC4;&#x7684;&#x6269;&#x5C55;</a></li><ul><li><span class="title-icon "></span><a href="#&#x6269;&#x5C55;&#x8FD0;&#x7B97;&#x7B26;-"><b>1.10.1. </b>&#x6269;&#x5C55;&#x8FD0;&#x7B97;&#x7B26; ...</a></li><li><span class="title-icon "></span><a href="#&#x6570;&#x7EC4;&#x76F8;&#x5173;&#x7684;&#x51FD;&#x6570;"><b>1.10.2. </b>&#x6570;&#x7EC4;&#x76F8;&#x5173;&#x7684;&#x51FD;&#x6570;</a></li></ul><li><span class="title-icon "></span><a href="#&#x5BF9;&#x8C61;&#x7684;&#x6269;&#x5C55;"><b>1.11. </b>&#x5BF9;&#x8C61;&#x7684;&#x6269;&#x5C55;</a></li><ul><li><span class="title-icon "></span><a href="#&#x5C5E;&#x6027;&#x7684;&#x7B80;&#x6D01;&#x8868;&#x793A;"><b>1.11.1. </b>&#x5C5E;&#x6027;&#x7684;&#x7B80;&#x6D01;&#x8868;&#x793A;</a></li><li><span class="title-icon "></span><a href="#&#x65B9;&#x6CD5;&#x7684;&#x7B80;&#x6D01;&#x8868;&#x793A;"><b>1.11.2. </b>&#x65B9;&#x6CD5;&#x7684;&#x7B80;&#x6D01;&#x8868;&#x793A;</a></li><li><span class="title-icon "></span><a href="#&#x5BF9;&#x8C61;&#x76F8;&#x5173;&#x7684;&#x51FD;&#x6570;"><b>1.11.3. </b>&#x5BF9;&#x8C61;&#x76F8;&#x5173;&#x7684;&#x51FD;&#x6570;</a></li><li><span class="title-icon "></span><a href="#&#x904D;&#x5386;&#x5BF9;&#x8C61;&#x7684;&#x5C5E;&#x6027;"><b>1.11.4. </b>&#x904D;&#x5386;&#x5BF9;&#x8C61;&#x7684;&#x5C5E;&#x6027;</a></li><li><span class="title-icon "></span><a href="#super-&#x5173;&#x952E;&#x5B57;"><b>1.11.5. </b>super &#x5173;&#x952E;&#x5B57;</a></li><li><span class="title-icon "></span><a href="#symbol&#x76F8;&#x5173;&#x7684;&#x51FD;&#x6570;&#x3001;&#x5C5E;&#x6027;"><b>1.11.6. </b>Symbol&#x76F8;&#x5173;&#x7684;&#x51FD;&#x6570;&#x3001;&#x5C5E;&#x6027;</a></li></ul><li><span class="title-icon "></span><a href="#set--&#x6570;&#x636E;&#x7ED3;&#x6784;"><b>1.12. </b>Set  &#x6570;&#x636E;&#x7ED3;&#x6784;</a></li><li><span class="title-icon "></span><a href="#weakset-&#x6570;&#x636E;&#x7ED3;&#x6784;"><b>1.13. </b>WeakSet &#x6570;&#x636E;&#x7ED3;&#x6784;</a></li><li><span class="title-icon "></span><a href="#map-&#x6570;&#x636E;&#x7ED3;&#x6784;"><b>1.14. </b>Map &#x6570;&#x636E;&#x7ED3;&#x6784;</a></li><li><span class="title-icon "></span><a href="#weakmap-&#x6570;&#x636E;&#x7ED3;&#x6784;"><b>1.15. </b>WeakMap &#x6570;&#x636E;&#x7ED3;&#x6784;</a></li><li><span class="title-icon "></span><a href="#proxy-&#x4EE3;&#x7406;&#x5668;"><b>1.16. </b>Proxy &#x4EE3;&#x7406;&#x5668;</a></li><ul><li><span class="title-icon "></span><a href="#proxy&#x652F;&#x6301;&#x7684;&#x62E6;&#x622A;&#x64CD;&#x4F5C;"><b>1.16.1. </b>Proxy&#x652F;&#x6301;&#x7684;&#x62E6;&#x622A;&#x64CD;&#x4F5C;</a></li><li><span class="title-icon "></span><a href="#reflect-&#x53CD;&#x5C04;"><b>1.16.2. </b>Reflect &#x53CD;&#x5C04;</a></li><li><span class="title-icon "></span><a href="#reflect&#x5BF9;&#x8C61;&#x7684;&#x65B9;&#x6CD5;"><b>1.16.3. </b>Reflect&#x5BF9;&#x8C61;&#x7684;&#x65B9;&#x6CD5;</a></li></ul><li><span class="title-icon "></span><a href="#promise"><b>1.17. </b>Promise</a></li><ul><li><span class="title-icon "></span><a href="#promise-&#x5BF9;&#x8C61;&#x65B9;&#x6CD5;"><b>1.17.1. </b>Promise &#x5BF9;&#x8C61;&#x65B9;&#x6CD5;</a></li></ul><li><span class="title-icon "></span><a href="#iterator-&#x904D;&#x5386;&#x5668;-&#x3001;&#x8FED;&#x4EE3;&#x5668;"><b>1.18. </b>Iterator &#x904D;&#x5386;&#x5668; &#x3001;&#x8FED;&#x4EE3;&#x5668;</a></li><li><span class="title-icon "></span><a href="#yield-&#x8868;&#x8FBE;&#x5F0F;--&#x3001;-yield-&#x8868;&#x8FBE;&#x5F0F;"><b>1.19. </b>yield &#x8868;&#x8FBE;&#x5F0F;  &#x3001; yield* &#x8868;&#x8FBE;&#x5F0F;</a></li><li><span class="title-icon "></span><a href="#generator-&#x751F;&#x6210;&#x51FD;&#x6570;"><b>1.20. </b>Generator &#x751F;&#x6210;&#x51FD;&#x6570;</a></li><li><span class="title-icon "></span><a href="#async-&#x51FD;&#x6570;"><b>1.21. </b>async &#x51FD;&#x6570;</a></li><li><span class="title-icon "></span><a href="#class-&#x7C7B;"><b>1.22. </b>class &#x7C7B;</a></li><ul><li><span class="title-icon "></span><a href="#class-&#x8868;&#x8FBE;&#x5F0F;"><b>1.22.1. </b>Class &#x8868;&#x8FBE;&#x5F0F;</a></li><li><span class="title-icon "></span><a href="#class&#x7684;&#x7EE7;&#x627F;"><b>1.22.2. </b>class&#x7684;&#x7EE7;&#x627F;</a></li><li><span class="title-icon "></span><a href="#&#x7C7B;&#x7684;super&#x5173;&#x952E;&#x5B57;"><b>1.22.3. </b>&#x7C7B;&#x7684;super&#x5173;&#x952E;&#x5B57;</a></li><li><span class="title-icon "></span><a href="#mixin-&#x7EC4;&#x5408;&#x6A21;&#x5F0F;-&#x5B9E;&#x73B0;-&#x591A;&#x7EE7;&#x627F;"><b>1.22.4. </b>Mixin &#x7EC4;&#x5408;&#x6A21;&#x5F0F; &#x5B9E;&#x73B0; &#x591A;&#x7EE7;&#x627F;</a></li></ul><li><span class="title-icon "></span><a href="#&#x4FEE;&#x9970;&#x5668;-&#x3001;-decorator"><b>1.23. </b>&#x4FEE;&#x9970;&#x5668; &#x3001; Decorator</a></li><li><span class="title-icon "></span><a href="#&#x6A21;&#x5757;&#x5316;-&#x3001;module"><b>1.24. </b>&#x6A21;&#x5757;&#x5316; &#x3001;Module</a></li><li><span class="title-icon "></span><a href="#&#x4E8C;&#x8FDB;&#x5236;&#x6570;&#x7EC4;"><b>1.25. </b>&#x4E8C;&#x8FDB;&#x5236;&#x6570;&#x7EC4;</a></li><ul><li><span class="title-icon "></span><a href="#&#x4E8C;&#x8FDB;&#x5236;&#x6570;&#x7EC4;---arraybuffer"><b>1.25.1. </b>&#x4E8C;&#x8FDB;&#x5236;&#x6570;&#x7EC4; - ArrayBuffer</a></li><li><span class="title-icon "></span><a href="#&#x4E8C;&#x8FDB;&#x5236;&#x6570;&#x7EC4;---typedarray"><b>1.25.2. </b>&#x4E8C;&#x8FDB;&#x5236;&#x6570;&#x7EC4; - TypedArray</a></li><li><span class="title-icon "></span><a href="#&#x4E8C;&#x8FDB;&#x5236;&#x6570;&#x7EC4;---dataview"><b>1.25.3. </b>&#x4E8C;&#x8FDB;&#x5236;&#x6570;&#x7EC4; - DataView</a></li></ul></ul></ul></div><a href="#es6" id="anchorNavigationExGoTop"><i class="fa fa-arrow-up"></i></a><h1 id="es6"><a name="es6" class="anchor-navigation-ex-anchor" href="#es6"><i class="fa fa-link" aria-hidden="true"></i></a>1. ES6</h1>
<p>ECMAScript 6 &#x3001;ES2015
<a href="http://es6.ruanyifeng.com/" target="_blank">http://es6.ruanyifeng.com/</a>  </p>
<pre><code class="lang-xml">&#x662F;JavaScript&#x8BED;&#x8A00;&#x7684;&#x4E00;&#x79CD;&#x6807;&#x51C6;&#x3002;
&#x56E0;&#x4E3A;&#x5F53;&#x524D;&#x7248;&#x672C;&#x7684;ES6&#x662F;&#x5728;2015&#x5E74;&#x53D1;&#x5E03;&#x7684;&#xFF0C;&#x6240;&#x4EE5;&#x53C8;&#x79F0;ECMAScript 2015&#x3002;

React Native &#x5185;&#x7F6E;&#x4E86;&#x5BF9; ES2015 &#x6807;&#x51C6;&#x7684;&#x652F;&#x6301;&#x3002;
</code></pre>
<h2 id="ecmascript-&#x548C;-javascript-&#x7684;&#x5173;&#x7CFB;"><a name="ecmascript-&#x548C;-javascript-&#x7684;&#x5173;&#x7CFB;" class="anchor-navigation-ex-anchor" href="#ecmascript-&#x548C;-javascript-&#x7684;&#x5173;&#x7CFB;"><i class="fa fa-link" aria-hidden="true"></i></a>1.1. ECMAScript &#x548C; JavaScript &#x7684;&#x5173;&#x7CFB;</h2>
<pre><code class="lang-xml">ECMAScript&#x662F;JavaScript&#x7684;&#x4E00;&#x79CD;&#x89C4;&#x8303;&#xFF0C;
JavaScript&#x662F;ECMAScript&#x7684;&#x4E00;&#x79CD;&#x5B9E;&#x73B0;
</code></pre>
<h3 id="&#x67E5;&#x770B;&#x5F53;&#x524D;&#x6D4F;&#x89C8;&#x5668;&#x5BF9;es6-&#x7684;&#x652F;&#x6301;&#x7A0B;&#x5EA6;"><a name="&#x67E5;&#x770B;&#x5F53;&#x524D;&#x6D4F;&#x89C8;&#x5668;&#x5BF9;es6-&#x7684;&#x652F;&#x6301;&#x7A0B;&#x5EA6;" class="anchor-navigation-ex-anchor" href="#&#x67E5;&#x770B;&#x5F53;&#x524D;&#x6D4F;&#x89C8;&#x5668;&#x5BF9;es6-&#x7684;&#x652F;&#x6301;&#x7A0B;&#x5EA6;"><i class="fa fa-link" aria-hidden="true"></i></a>1.1.1. &#x67E5;&#x770B;&#x5F53;&#x524D;&#x6D4F;&#x89C8;&#x5668;&#x5BF9;ES6 &#x7684;&#x652F;&#x6301;&#x7A0B;&#x5EA6;</h3>
<p><a href="http://ruanyf.github.io/es-checker/" target="_blank">&#x70B9;&#x51FB;&#x67E5;&#x770B;</a></p>
<pre><code class="lang-xml">https://github.com/ruanyf/es-checker
</code></pre>
<h2 id="&#x53D8;&#x91CF;&#x7684;&#x58F0;&#x660E;"><a name="&#x53D8;&#x91CF;&#x7684;&#x58F0;&#x660E;" class="anchor-navigation-ex-anchor" href="#&#x53D8;&#x91CF;&#x7684;&#x58F0;&#x660E;"><i class="fa fa-link" aria-hidden="true"></i></a>1.2. &#x53D8;&#x91CF;&#x7684;&#x58F0;&#x660E;</h2>
<pre><code class="lang-xml">ES5&#x652F;&#x6301;&#x7684; var &#x3001;function
ES6&#x65B0;&#x589E; &#xFF1A;const&#x3001;let&#x3001;class&#x3001;import
</code></pre>
<h2 id="let---&#x547D;&#x4EE4;"><a name="let---&#x547D;&#x4EE4;" class="anchor-navigation-ex-anchor" href="#let---&#x547D;&#x4EE4;"><i class="fa fa-link" aria-hidden="true"></i></a>1.3. let   &#x547D;&#x4EE4;</h2>
<pre><code class="lang-xml">ES6 &#x65B0;&#x589E;&#x4E86;let &#x547D;&#x4EE4;&#xFF0C;&#x7528;&#x6765;&#x58F0;&#x660E;&#x53D8;&#x91CF;&#x3002;
&#x5B83;&#x7684;&#x7528;&#x6CD5;&#x7C7B;&#x4F3C;&#x4E8E;var&#xFF0C;let &#x58F0;&#x660E;&#x7684;&#x53D8;&#x91CF;&#xFF0C;&#x53EA;&#x5728;let&#x547D;&#x4EE4;&#x6240;&#x5728;&#x7684;&#x4EE3;&#x7801;&#x5757;&#x5185;&#x6709;&#x6548;&#x3002;
{
  let a = 10;
  var b = 1;
}

{
 // let&#x4E0D;&#x5141;&#x8BB8;&#x5728;&#x76F8;&#x540C;&#x4F5C;&#x7528;&#x57DF;&#x5185;&#xFF0C;&#x91CD;&#x590D;&#x58F0;&#x660E;&#x540C;&#x4E00;&#x4E2A;&#x53D8;&#x91CF;&#x3002; &#xFF08;let&#x4E0D;&#x5141;&#x8BB8;&#x5728;&#x76F8;&#x540C;&#x4F5C;&#x7528;&#x57DF;&#x5185;&#xFF0C;&#x91CD;&#x590D;&#x58F0;&#x660E;&#x540C;&#x4E00;&#x4E2A;&#x53D8;&#x91CF;&#x3002;&#xFF09;
  var a = 10;
  //&#x4F1A;&#x62A5;&#x9519;
  var a = 1;
}

ES5 &#x53EA;&#x6709;&#x5168;&#x5C40;&#x4F5C;&#x7528;&#x57DF;&#x548C;&#x51FD;&#x6570;&#x4F5C;&#x7528;&#x57DF; &#xFF08;&#x7528;var&#x5B9A;&#x4E49;&#xFF09;&#x3002;ES6&#x65B0;&#x589E;&#x4E86; &#x5757;&#x7EA7;&#x4F5C;&#x7528;&#x57DF;&#xFF08;&#x7528;let&#x5B9A;&#x4E49;&#xFF09; &#x3002;
</code></pre>
<h2 id="&#x53D8;&#x91CF;&#x7684;-&#x89E3;&#x6784;&#x8D4B;&#x503C;"><a name="&#x53D8;&#x91CF;&#x7684;-&#x89E3;&#x6784;&#x8D4B;&#x503C;" class="anchor-navigation-ex-anchor" href="#&#x53D8;&#x91CF;&#x7684;-&#x89E3;&#x6784;&#x8D4B;&#x503C;"><i class="fa fa-link" aria-hidden="true"></i></a>1.4. &#x53D8;&#x91CF;&#x7684; &#x89E3;&#x6784;&#x8D4B;&#x503C;</h2>
<p>ES6 &#x5141;&#x8BB8;&#x6309;&#x7167;&#x4E00;&#x5B9A;&#x6A21;&#x5F0F;&#xFF0C;&#x4ECE;&#x6570;&#x7EC4;&#x548C;&#x5BF9;&#x8C61;&#x4E2D;&#x63D0;&#x53D6;&#x503C;&#xFF0C;&#x5BF9;&#x53D8;&#x91CF;&#x8FDB;&#x884C;&#x8D4B;&#x503C;&#xFF0C;&#x8FD9;&#x88AB;&#x79F0;&#x4E3A;&#x89E3;&#x6784;&#xFF08;Destructuring&#xFF09;&#x3002;</p>
<pre><code class="lang-xml">// &#x7528;&#x6570;&#x7EC4;&#x8D4B;&#x503C;
let [a, b, c] = [1, 2, 3];
let [x, y, z] = new Set([&apos;a&apos;, &apos;b&apos;, &apos;c&apos;]);
// &#x6307;&#x5B9A;&#x9ED8;&#x8BA4;&#x503C;
let [x, y = &apos;b&apos;] = [&apos;a&apos;]; // x=&apos;a&apos;, y=&apos;b&apos;
//&#x7528;&#x5BF9;&#x8C61;&#x590D;&#x5236;
let { foo, bar } = { foo: &quot;aaa&quot;, bar: &quot;bbb&quot; };
//&#x7528;&#x5B57;&#x7B26;&#x4E32;&#x8D4B;&#x503C;
const [a, b, c, d, e] = &apos;hello&apos;;

// &#x7528;json&#x6570;&#x636E;&#x8D4B;&#x503C;
let jsonData = {
  id: 42,
  status: &quot;OK&quot;,
  data: [867, 5309]
};
let { id, status, data: number } = jsonData;

// &#x4ECE;&#x51FD;&#x6570;&#x8D4B;&#x503C;
function example() {
  return [1, 2, 3];
}
let [a, b, c] = example();
</code></pre>
<h2 id="const-&#x547D;&#x4EE4;"><a name="const-&#x547D;&#x4EE4;" class="anchor-navigation-ex-anchor" href="#const-&#x547D;&#x4EE4;"><i class="fa fa-link" aria-hidden="true"></i></a>1.5. const &#x547D;&#x4EE4;</h2>
<pre><code class="lang-xml"> const&#x58F0;&#x660E;&#x4E00;&#x4E2A;&#x53EA;&#x8BFB;&#x7684;&#x5E38;&#x91CF;&#x3002;&#x4E00;&#x65E6;&#x58F0;&#x660E;&#xFF0C;&#x5E38;&#x91CF;&#x7684;&#x503C;&#x5C31;&#x4E0D;&#x80FD;&#x6539;&#x53D8;&#x3002;
 const&#x7684;&#x4F5C;&#x7528;&#x57DF;&#x4E0E;let&#x547D;&#x4EE4;&#x76F8;&#x540C;&#xFF1A;&#x53EA;&#x5728;&#x58F0;&#x660E;&#x6240;&#x5728;&#x7684;&#x5757;&#x7EA7;&#x4F5C;&#x7528;&#x57DF;&#x5185;&#x6709;&#x6548;&#x3002;
</code></pre>
<h2 id="&#x5B57;&#x7B26;&#x4E32;&#x7684;&#x6269;&#x5C55;"><a name="&#x5B57;&#x7B26;&#x4E32;&#x7684;&#x6269;&#x5C55;" class="anchor-navigation-ex-anchor" href="#&#x5B57;&#x7B26;&#x4E32;&#x7684;&#x6269;&#x5C55;"><i class="fa fa-link" aria-hidden="true"></i></a>1.6. &#x5B57;&#x7B26;&#x4E32;&#x7684;&#x6269;&#x5C55;</h2>
<pre><code class="lang-xml">ES6 &#x52A0;&#x5F3A;&#x4E86;&#x5BF9; Unicode &#x7684;&#x652F;&#x6301;, &quot;\u{xxxx}&quot; // xxxx &#x8868;&#x793A;&#x5B57;&#x7B26;&#x7684; Unicode &#x7801; &#x3002;

// for ...  of &#x904D;&#x5386;&#x5B57;&#x7B26;&#x4E32;
for (let i of text) { ... }
</code></pre>
<table>
<thead>
<tr>
<th>String&#x76F8;&#x5173;&#x51FD;&#x6570;</th>
<th>&#x8BF4;&#x660E;</th>
</tr>
</thead>
<tbody>
<tr>
<td>String.raw()</td>
<td>&#x4F5C;&#x4E3A;&#x5904;&#x7406;&#x6A21;&#x677F;&#x5B57;&#x7B26;&#x4E32;&#x7684;&#x57FA;&#x672C;&#x65B9;&#x6CD5;&#xFF0C;&#x5B83;&#x4F1A;&#x5C06;&#x6240;&#x6709;&#x53D8;&#x91CF;&#x66FF;&#x6362; <br> String.raw({ raw: &apos;test&apos; }, 0, 1, 2);</td>
</tr>
<tr>
<td>matchAll</td>
<td>&#x4E00;&#x6B21;&#x6027;&#x53D6;&#x51FA;&#x6240;&#x6709;&#x5339;&#x914D;  <br> for (const match of string.matchAll(regex)) {...}</td>
</tr>
<tr>
<td>includes(xx)</td>
<td>&#x662F;&#x5426;&#x627E;&#x5230;&#x4E86;&#x53C2;&#x6570;&#x5B57;&#x7B26;&#x4E32;xx</td>
</tr>
<tr>
<td>startsWith(xx)</td>
<td>&#x5B57;&#x7B26;&#x4E32;xx&#x662F;&#x5426;&#x5728;&#x539F;&#x5B57;&#x7B26;&#x4E32;&#x7684;&#x5934;&#x90E8;</td>
</tr>
<tr>
<td>endsWith(xx)</td>
<td>&#x5B57;&#x7B26;&#x4E32;xx&#x662F;&#x5426;&#x5728;&#x539F;&#x5B57;&#x7B26;&#x4E32;&#x7684;&#x5C3E;&#x90E8;</td>
</tr>
<tr>
<td>&apos;hello&apos;.repeat(2)</td>
<td>// &quot;hellohello&quot;  <br> &#x8FD4;&#x56DE;&#x4E00;&#x4E2A;&#x65B0;&#x5B57;&#x7B26;&#x4E32;&#xFF0C;&#x5C06;&#x539F;&#x5B57;&#x7B26;&#x4E32;&#x91CD;&#x590D;n&#x6B21;</td>
</tr>
<tr>
<td>&apos;x&apos;.padStart(4, &apos;ab&apos;)</td>
<td>// &apos;abax&apos;  <br>  &#x5B57;&#x7B26;&#x4E32;&#x8865;&#x5168;&#x957F;&#x5EA6;</td>
</tr>
<tr>
<td>&apos;x&apos;.padEnd(5, &apos;ab&apos;)</td>
<td>&apos;xabab&apos;</td>
</tr>
<tr>
<td>s1.codePointAt(0)</td>
<td>&#x8FD4;&#x56DE;&#x4E0E;&#x5B57;&#x7B26;&#x4E32;&#x4E2D;&#x7ED9;&#x5B9A;&#x4F4D;&#x7F6E;&#x5BF9;&#x5E94;&#x7684;&#x7801;&#x4F4D;</td>
</tr>
<tr>
<td>String.fromCodePoint(0x20BB7)</td>
<td>&#x4ECE;&#x7801;&#x70B9;&#x8FD4;&#x56DE;&#x5BF9;&#x5E94;&#x5B57;&#x7B26;</td>
</tr>
<tr>
<td>normalize()</td>
<td>&#x5C06;&#x5B57;&#x7B26;&#x7684;&#x4E0D;&#x540C;&#x8868;&#x793A;&#x65B9;&#x6CD5;&#x7EDF;&#x4E00;&#x4E3A;&#x540C;&#x6837;&#x7684;&#x5F62;&#x5F0F; <br>  &apos;\u01D1&apos;.normalize() === &apos;\u004F\u030C&apos;.normalize()</td>
</tr>
</tbody>
</table>
<h3 id="&#x6A21;&#x677F;&#x5B57;&#x7B26;&#x4E32;"><a name="&#x6A21;&#x677F;&#x5B57;&#x7B26;&#x4E32;" class="anchor-navigation-ex-anchor" href="#&#x6A21;&#x677F;&#x5B57;&#x7B26;&#x4E32;"><i class="fa fa-link" aria-hidden="true"></i></a>1.6.1. &#x6A21;&#x677F;&#x5B57;&#x7B26;&#x4E32;</h3>
<pre><code class="lang-xml">let msg = `Hello ${name}, how are you ${time}?`
</code></pre>
<h3 id="&#x6807;&#x7B7E;&#x6A21;&#x677F;"><a name="&#x6807;&#x7B7E;&#x6A21;&#x677F;" class="anchor-navigation-ex-anchor" href="#&#x6807;&#x7B7E;&#x6A21;&#x677F;"><i class="fa fa-link" aria-hidden="true"></i></a>1.6.2. &#x6807;&#x7B7E;&#x6A21;&#x677F;</h3>
<pre><code class="lang-xml">function myFunc(s, v1, v2, v3) {
  console.log(&quot;s=&quot; + s); //s[0]&#x7684;&#x5185;&#x5BB9;,s[1]&#x7684;&#x5185;&#x5BB9; ,s[2]&#x7684;&#x5185;&#x5BB9;,s[3]&#x7684;&#x5185;&#x5BB9;
  console.log(&quot;0=&quot; + s[0]); // s[0]&#x7684;&#x5185;&#x5BB9;
  console.log(&quot;1=&quot; + s[1]); //s[1]&#x7684;&#x5185;&#x5BB9;
  console.log(&quot;2=&quot; + s[2]); //s[2]&#x7684;&#x5185;&#x5BB9;
  console.log(&quot;3=&quot; + s[3]); //s[3]&#x7684;&#x5185;&#x5BB9;
  console.log(&quot;4=&quot; + s[4]); // undefined
  console.log(&quot;v1=&quot; + v1); // 15
  console.log(&quot;v2=&quot; + v2); // 50
  console.log(&quot;v3=&quot; + v3); // 10
  return &quot;OK&quot;;
}
// &#x6CE8;&#x610F; s&#x7684;&#x6570;&#x7EC4;&#x5185;&#x5BB9;&#x662F;&#x8DDF; &#x53C2;&#x6570; v1&#x3001;v2&#x3001;v3&#x7684;&#x4F4D;&#x7F6E;&#x6709;&#x5173;&#x7684;
// &#x5982;&#x679C;&#x662F; &#x51E0;&#x4E2A;${}&#x662F;&#x8FDE;&#x7EED;&#x7684;&#xFF0C;&#x53EA;&#x6709;s[0]&#x6709;&#x6570;&#x636E;&#x7684; &#x3002; &#x5177;&#x4F53;&#x89C4;&#x5219;&#x8BF7;&#x4ED4;&#x7EC6;&#x89C2;&#x6469;&#x4F8B;&#x5B50;
myFunc `s[0]&#x7684;&#x5185;&#x5BB9;${ a + b }s[1]&#x7684;&#x5185;&#x5BB9; ${ a * b}s[2]&#x7684;&#x5185;&#x5BB9;${10}s[3]&#x7684;&#x5185;&#x5BB9;`;
</code></pre>
<h2 id="&#x6B63;&#x5219;&#x7684;&#x6269;&#x5C55;"><a name="&#x6B63;&#x5219;&#x7684;&#x6269;&#x5C55;" class="anchor-navigation-ex-anchor" href="#&#x6B63;&#x5219;&#x7684;&#x6269;&#x5C55;"><i class="fa fa-link" aria-hidden="true"></i></a>1.7. &#x6B63;&#x5219;&#x7684;&#x6269;&#x5C55;</h2>
<h3 id="&#x6784;&#x9020;&#x51FD;&#x6570;&#x53C2;&#x6570;-&#x6709;&#x6539;&#x53D8;"><a name="&#x6784;&#x9020;&#x51FD;&#x6570;&#x53C2;&#x6570;-&#x6709;&#x6539;&#x53D8;" class="anchor-navigation-ex-anchor" href="#&#x6784;&#x9020;&#x51FD;&#x6570;&#x53C2;&#x6570;-&#x6709;&#x6539;&#x53D8;"><i class="fa fa-link" aria-hidden="true"></i></a>1.7.1. &#x6784;&#x9020;&#x51FD;&#x6570;&#x53C2;&#x6570; &#x6709;&#x6539;&#x53D8;</h3>
<pre><code class="lang-xml">&#x7B2C;&#x4E00;&#x4E2A;&#x53C2;&#x6570;&#xFF1A;&#x662F;&#x4E00;&#x4E2A;&#x6B63;&#x5219;&#x5BF9;&#x8C61;
&#x7B2C;&#x4E8C;&#x4E2A;&#x53C2;&#x6570;&#xFF1A; &#x6307;&#x5B9A;&#x4FEE;&#x9970;&#x7B26;
new RegExp(/abc/ig, &apos;i&apos;).flags
</code></pre>
<h3 id="&#x5B57;&#x7B26;&#x4E32;&#x7684;&#x6B63;&#x5219;&#x65B9;&#x6CD5;"><a name="&#x5B57;&#x7B26;&#x4E32;&#x7684;&#x6B63;&#x5219;&#x65B9;&#x6CD5;" class="anchor-navigation-ex-anchor" href="#&#x5B57;&#x7B26;&#x4E32;&#x7684;&#x6B63;&#x5219;&#x65B9;&#x6CD5;"><i class="fa fa-link" aria-hidden="true"></i></a>1.7.2. &#x5B57;&#x7B26;&#x4E32;&#x7684;&#x6B63;&#x5219;&#x65B9;&#x6CD5;</h3>
<pre><code class="lang-xml">String.prototype.match &#x8C03;&#x7528; RegExp.prototype[Symbol.match]
String.prototype.replace &#x8C03;&#x7528; RegExp.prototype[Symbol.replace]
String.prototype.search &#x8C03;&#x7528; RegExp.prototype[Symbol.search]
String.prototype.split &#x8C03;&#x7528; RegExp.prototype[Symbol.split]
</code></pre>
<h3 id="u-&#x4FEE;&#x9970;&#x7B26;"><a name="u-&#x4FEE;&#x9970;&#x7B26;" class="anchor-navigation-ex-anchor" href="#u-&#x4FEE;&#x9970;&#x7B26;"><i class="fa fa-link" aria-hidden="true"></i></a>1.7.3. u &#x4FEE;&#x9970;&#x7B26;</h3>
<pre><code class="lang-xml">ES6 &#x5BF9;&#x6B63;&#x5219;&#x8868;&#x8FBE;&#x5F0F;&#x6DFB;&#x52A0;&#x4E86;u&#x4FEE;&#x9970;&#x7B26;&#xFF0C;&#x542B;&#x4E49;&#x4E3A;&#x201C;Unicode &#x6A21;&#x5F0F;&#x201D;&#xFF0C;&#x4F1A;&#x6B63;&#x786E;&#x5904;&#x7406;&#x56DB;&#x4E2A;&#x5B57;&#x8282;&#x7684; UTF-16 &#x7F16;&#x7801;&#x3002;

// unicode &#x5C5E;&#x6027; , &#x7528;&#x6765;&#x67E5;&#x770B;&#x662F;&#x5426;&#x8BBE;&#x7F6E;&#x4E86;u&#x4FEE;&#x9970;&#x7B26;
r1.unicode
</code></pre>
<h3 id="y-&#x4FEE;&#x9970;&#x7B26;"><a name="y-&#x4FEE;&#x9970;&#x7B26;" class="anchor-navigation-ex-anchor" href="#y-&#x4FEE;&#x9970;&#x7B26;"><i class="fa fa-link" aria-hidden="true"></i></a>1.7.4. y &#x4FEE;&#x9970;&#x7B26;</h3>
<pre><code class="lang-xml">ES6 &#x4E3A;&#x6B63;&#x5219;&#x8868;&#x8FBE;&#x5F0F;&#x6DFB;&#x52A0;&#x4E86;y&#x4FEE;&#x9970;&#x7B26;&#xFF0C;&#x53EB;&#x505A;&#x201C;&#x7C98;&#x8FDE;&#x201D;&#xFF08;sticky&#xFF09;&#x4FEE;&#x9970;&#x7B26;&#x3002;

&#x540E;&#x4E00;&#x6B21;&#x5339;&#x914D;&#x90FD;&#x4ECE;&#x4E0A;&#x4E00;&#x6B21;&#x5339;&#x914D;&#x6210;&#x529F;&#x7684;&#x4E0B;&#x4E00;&#x4E2A;&#x4F4D;&#x7F6E;&#x5F00;&#x59CB;&#x3002;
y&#x4FEE;&#x9970;&#x7B26;&#x786E;&#x4FDD;&#x5339;&#x914D;&#x5FC5;&#x987B;&#x4ECE;&#x5269;&#x4F59;&#x7684;&#x7B2C;&#x4E00;&#x4E2A;&#x4F4D;&#x7F6E;&#x5F00;&#x59CB;&#xFF0C;&#x8FD9;&#x4E5F;&#x5C31;&#x662F;&#x201C;&#x7C98;&#x8FDE;&#x201D;&#x7684;&#x6DB5;&#x4E49;&#x3002;

//sticky &#x5C5E;&#x6027; , &#x8868;&#x793A;&#x662F;&#x5426;&#x8BBE;&#x7F6E;&#x4E86;y&#x4FEE;&#x9970;&#x7B26;&#x3002;
var r = /hello\d/y;
r.sticky // true
</code></pre>
<h3 id="flags-&#x5C5E;&#x6027;"><a name="flags-&#x5C5E;&#x6027;" class="anchor-navigation-ex-anchor" href="#flags-&#x5C5E;&#x6027;"><i class="fa fa-link" aria-hidden="true"></i></a>1.7.5. flags &#x5C5E;&#x6027;</h3>
<pre><code class="lang-xml">ES6 &#x4E3A;&#x6B63;&#x5219;&#x8868;&#x8FBE;&#x5F0F;&#x65B0;&#x589E;&#x4E86;flags&#x5C5E;&#x6027;&#xFF0C;&#x4F1A;&#x8FD4;&#x56DE;&#x6B63;&#x5219;&#x8868;&#x8FBE;&#x5F0F;&#x7684;&#x4FEE;&#x9970;&#x7B26;&#x3002;
/abc/ig.flags
// &apos;gi&apos;
</code></pre>
<h2 id="&#x6570;&#x503C;&#x7684;&#x6269;&#x5C55;"><a name="&#x6570;&#x503C;&#x7684;&#x6269;&#x5C55;" class="anchor-navigation-ex-anchor" href="#&#x6570;&#x503C;&#x7684;&#x6269;&#x5C55;"><i class="fa fa-link" aria-hidden="true"></i></a>1.8. &#x6570;&#x503C;&#x7684;&#x6269;&#x5C55;</h2>
<p>ES6 &#x63D0;&#x4F9B;&#x4E86;&#x4E8C;&#x8FDB;&#x5236;&#x548C;&#x516B;&#x8FDB;&#x5236;&#x6570;&#x503C;&#x7684;&#x65B0;&#x7684;&#x5199;&#x6CD5;&#xFF0C;&#x5206;&#x522B;&#x7528;&#x524D;&#x7F00;0b&#xFF08;&#x6216;0B&#xFF09;&#x548C;0o&#xFF08;&#x6216;0O&#xFF09;&#x8868;&#x793A;&#x3002;</p>
<h3 id="&#x6570;&#x503C;-&#x65B0;&#x589E;&#x51FD;&#x6570;"><a name="&#x6570;&#x503C;-&#x65B0;&#x589E;&#x51FD;&#x6570;" class="anchor-navigation-ex-anchor" href="#&#x6570;&#x503C;-&#x65B0;&#x589E;&#x51FD;&#x6570;"><i class="fa fa-link" aria-hidden="true"></i></a>1.8.1. &#x6570;&#x503C; &#x65B0;&#x589E;&#x51FD;&#x6570;</h3>
<table>
<thead>
<tr>
<th>&#x51FD;&#x6570;</th>
<th>&#x8BF4;&#x660E;</th>
</tr>
</thead>
<tbody>
<tr>
<td>Number.isFinite()</td>
<td>&#x7528;&#x6765;&#x68C0;&#x67E5;&#x4E00;&#x4E2A;&#x6570;&#x503C;&#x662F;&#x5426;&#x4E3A;&#x6709;&#x9650;&#x7684;</td>
</tr>
<tr>
<td>Number.isNaN()</td>
<td>&#x7528;&#x6765;&#x68C0;&#x67E5;&#x4E00;&#x4E2A;&#x503C;&#x662F;&#x5426;&#x4E3A;NaN</td>
</tr>
<tr>
<td>Number.parseInt()</td>
<td></td>
</tr>
<tr>
<td>Number.parseFloat()</td>
<td></td>
</tr>
<tr>
<td>Number.isInteger()</td>
<td>&#x4E00;&#x4E2A;&#x6570;&#x503C;&#x662F;&#x5426;&#x4E3A;&#x6574;&#x6570;</td>
</tr>
<tr>
<td>Number.EPSILON</td>
<td>&#x5E38;&#x91CF; &#x3002; &#x8868;&#x793A; 1 &#x4E0E;&#x5927;&#x4E8E; 1 &#x7684;&#x6700;&#x5C0F;&#x6D6E;&#x70B9;&#x6570;&#x4E4B;&#x95F4;&#x7684;&#x5DEE;&#x3002;</td>
</tr>
<tr>
<td>Number.isSafeInteger()</td>
<td>&#x5224;&#x65AD;&#x4E00;&#x4E2A;&#x6574;&#x6570;&#x662F;&#x5426;&#x843D;&#x5728;&#x8FD9;&#x4E2A;&#x8303;&#x56F4;&#x4E4B;&#x5185; &#x3002; Number.MAX_SAFE_INTEGER  <br>  Number.MIN_SAFE_INTEGER</td>
</tr>
<tr>
<td>Math.trunc()</td>
<td>&#x7528;&#x4E8E;&#x53BB;&#x9664;&#x4E00;&#x4E2A;&#x6570;&#x7684;&#x5C0F;&#x6570;&#x90E8;&#x5206;&#xFF0C;&#x8FD4;&#x56DE;&#x6574;&#x6570;&#x90E8;&#x5206;</td>
</tr>
<tr>
<td>Math.sign()</td>
<td>&#x7528;&#x6765;&#x5224;&#x65AD;&#x4E00;&#x4E2A;&#x6570;&#x5230;&#x5E95;&#x662F;&#x6B63;&#x6570;&#x3001;&#x8D1F;&#x6570;&#x3001;&#x8FD8;&#x662F;&#x96F6;&#x3002;&#x5BF9;&#x4E8E;&#x975E;&#x6570;&#x503C;&#xFF0C;&#x4F1A;&#x5148;&#x5C06;&#x5176;&#x8F6C;&#x6362;&#x4E3A;&#x6570;&#x503C;&#x3002;   <br>  &#x6B63;&#x6570;&#x8FD4;&#x56DE;+1  <br> &#x8D1F;&#x6570;&#xFF0C;&#x8FD4;&#x56DE;-1  <br> 0&#xFF0C;&#x8FD4;&#x56DE;0 <br> -0&#xFF0C;&#x8FD4;&#x56DE;-0 <br> &#x5176;&#x4ED6;&#x503C;&#xFF0C;&#x8FD4;&#x56DE;NaN</td>
</tr>
<tr>
<td>Math.cbrt()</td>
<td>&#x7528;&#x4E8E;&#x8BA1;&#x7B97;&#x4E00;&#x4E2A;&#x6570;&#x7684;&#x7ACB;&#x65B9;&#x6839;</td>
</tr>
<tr>
<td>Math.clz32()</td>
<td>&#x8FD4;&#x56DE;&#x4E00;&#x4E2A;&#x6570;&#x7684; 32 &#x4F4D;&#x65E0;&#x7B26;&#x53F7;&#x6574;&#x6570;&#x5F62;&#x5F0F;&#x6709;&#x591A;&#x5C11;&#x4E2A;&#x524D;&#x5BFC; 0</td>
</tr>
<tr>
<td>Math.imul()</td>
<td>&#x8FD4;&#x56DE;&#x4E24;&#x4E2A;&#x6570;&#x4EE5; 32 &#x4F4D;&#x5E26;&#x7B26;&#x53F7;&#x6574;&#x6570;&#x5F62;&#x5F0F;&#x76F8;&#x4E58;&#x7684;&#x7ED3;&#x679C;</td>
</tr>
<tr>
<td>Math.fround()</td>
<td>&#x8FD4;&#x56DE;&#x4E00;&#x4E2A;&#x6570;&#x7684;32&#x4F4D;&#x5355;&#x7CBE;&#x5EA6;&#x6D6E;&#x70B9;&#x6570;&#x5F62;&#x5F0F;</td>
</tr>
<tr>
<td>Math.hypot()</td>
<td>&#x8FD4;&#x56DE;&#x6240;&#x6709;&#x53C2;&#x6570;&#x7684;&#x5E73;&#x65B9;&#x548C;&#x7684;&#x5E73;&#x65B9;&#x6839;</td>
</tr>
<tr>
<td>Math.expm1()</td>
<td>&#x5373;Math.exp(x) - 1</td>
</tr>
<tr>
<td>Math.log1p()</td>
<td>&#x5373;Math.log(1 + x)</td>
</tr>
<tr>
<td>Math.log10()</td>
<td>&#x56DE;&#x4EE5; 10 &#x4E3A;&#x5E95;&#x7684;x&#x7684;&#x5BF9;&#x6570;</td>
</tr>
<tr>
<td>Math.log2()</td>
<td>&#x8FD4;&#x56DE;&#x4EE5; 2 &#x4E3A;&#x5E95;&#x7684;x&#x7684;&#x5BF9;&#x6570;</td>
</tr>
<tr>
<td>Math.sinh(x)</td>
<td>&#x8FD4;&#x56DE;x&#x7684;&#x53CC;&#x66F2;&#x6B63;&#x5F26;</td>
</tr>
<tr>
<td>Math.cosh(x)</td>
<td>&#x8FD4;&#x56DE;x&#x7684;&#x53CC;&#x66F2;&#x4F59;&#x5F26;</td>
</tr>
<tr>
<td>Math.tanh(x)</td>
<td>&#x8FD4;&#x56DE;x&#x7684;&#x53CC;&#x66F2;&#x6B63;&#x5207;</td>
</tr>
<tr>
<td>Math.asinh(x)</td>
<td>&#x8FD4;&#x56DE;x&#x7684;&#x53CD;&#x53CC;&#x66F2;&#x6B63;&#x5F26;</td>
</tr>
<tr>
<td>Math.acosh(x)</td>
<td>&#x8FD4;&#x56DE;x&#x7684;&#x53CD;&#x53CC;&#x66F2;&#x4F59;&#x5F26;</td>
</tr>
<tr>
<td>Math.atanh(x)</td>
<td>&#x8FD4;&#x56DE;x&#x7684;&#x53CD;&#x53CC;&#x66F2;&#x6B63;&#x5207;</td>
</tr>
</tbody>
</table>
<h3 id="&#x6307;&#x6570;&#x8FD0;&#x7B97;&#x7B26;"><a name="&#x6307;&#x6570;&#x8FD0;&#x7B97;&#x7B26;" class="anchor-navigation-ex-anchor" href="#&#x6307;&#x6570;&#x8FD0;&#x7B97;&#x7B26;"><i class="fa fa-link" aria-hidden="true"></i></a>1.8.2. &#x6307;&#x6570;&#x8FD0;&#x7B97;&#x7B26;</h3>
<p>ES2016 &#x65B0;&#x589E;&#x4E86;&#x4E00;&#x4E2A;&#x6307;&#x6570;&#x8FD0;&#x7B97;&#x7B26;&#xFF08;**&#xFF09;&#x3002;</p>
<pre><code class="lang-xml">2 ** 3 // 8
</code></pre>
<h2 id="&#x51FD;&#x6570;&#x7684;&#x6269;&#x5C55;"><a name="&#x51FD;&#x6570;&#x7684;&#x6269;&#x5C55;" class="anchor-navigation-ex-anchor" href="#&#x51FD;&#x6570;&#x7684;&#x6269;&#x5C55;"><i class="fa fa-link" aria-hidden="true"></i></a>1.9. &#x51FD;&#x6570;&#x7684;&#x6269;&#x5C55;</h2>
<h3 id="&#x51FD;&#x6570;&#x53C2;&#x6570;-&#x8BBE;&#x7F6E;&#x9ED8;&#x8BA4;&#x503C;"><a name="&#x51FD;&#x6570;&#x53C2;&#x6570;-&#x8BBE;&#x7F6E;&#x9ED8;&#x8BA4;&#x503C;" class="anchor-navigation-ex-anchor" href="#&#x51FD;&#x6570;&#x53C2;&#x6570;-&#x8BBE;&#x7F6E;&#x9ED8;&#x8BA4;&#x503C;"><i class="fa fa-link" aria-hidden="true"></i></a>1.9.1. &#x51FD;&#x6570;&#x53C2;&#x6570; &#x8BBE;&#x7F6E;&#x9ED8;&#x8BA4;&#x503C;</h3>
<p>&#x6307;&#x5B9A;&#x4E86;&#x9ED8;&#x8BA4;&#x503C;&#x4EE5;&#x540E;&#xFF0C;&#x51FD;&#x6570;&#x7684;length&#x5C5E;&#x6027;&#xFF0C;&#x5C06;&#x8FD4;&#x56DE;&#x6CA1;&#x6709;&#x6307;&#x5B9A;&#x9ED8;&#x8BA4;&#x503C;&#x7684;&#x53C2;&#x6570;&#x4E2A;&#x6570;&#x3002;</p>
<pre><code class="lang-xml">function log(x, y) {
  y = y || &apos;World&apos;;
}

function foo({x, y = 5}) { ... }
</code></pre>
<h3 id="rest-&#x53C2;&#x6570;"><a name="rest-&#x53C2;&#x6570;" class="anchor-navigation-ex-anchor" href="#rest-&#x53C2;&#x6570;"><i class="fa fa-link" aria-hidden="true"></i></a>1.9.2. rest &#x53C2;&#x6570;</h3>
<p>ES6 &#x5F15;&#x5165; rest &#x53C2;&#x6570;&#xFF08;&#x5F62;&#x5F0F;&#x4E3A;...&#x53D8;&#x91CF;&#x540D;&#xFF09;&#xFF0C;&#x7528;&#x4E8E;&#x83B7;&#x53D6;&#x51FD;&#x6570;&#x7684;&#x591A;&#x4F59;&#x53C2;&#x6570;&#xFF0C;&#x8FD9;&#x6837;&#x5C31;&#x4E0D;&#x9700;&#x8981;&#x4F7F;&#x7528;arguments&#x5BF9;&#x8C61;&#x4E86;&#x3002;</p>
<pre><code class="lang-xml">function add(...values) {
   ...
}
add(2, 5, 3) ;
</code></pre>
<h3 id="&#x7BAD;&#x5934;&#x51FD;&#x6570;-&#x3001;-lambda-&#x8868;&#x8FBE;&#x5F0F;"><a name="&#x7BAD;&#x5934;&#x51FD;&#x6570;-&#x3001;-lambda-&#x8868;&#x8FBE;&#x5F0F;" class="anchor-navigation-ex-anchor" href="#&#x7BAD;&#x5934;&#x51FD;&#x6570;-&#x3001;-lambda-&#x8868;&#x8FBE;&#x5F0F;"><i class="fa fa-link" aria-hidden="true"></i></a>1.9.3. &#x7BAD;&#x5934;&#x51FD;&#x6570; &#x3001; Lambda &#x8868;&#x8FBE;&#x5F0F;</h3>
<p>ES6 &#x5141;&#x8BB8;&#x4F7F;&#x7528;&#x201C;&#x7BAD;&#x5934;&#x201D;&#xFF08;=&gt;&#xFF09;&#x5B9A;&#x4E49;&#x51FD;&#x6570;&#x3002;
&#x7BAD;&#x5934;&#x51FD;&#x6570;&#x76F8;&#x5F53;&#x4E8E;&#x533F;&#x540D;&#x51FD;&#x6570;&#xFF0C;&#x5E76;&#x4E14;&#x7B80;&#x5316;&#x4E86;&#x51FD;&#x6570;&#x5B9A;&#x4E49;&#x3002;</p>
<pre><code class="lang-xml">var f = () =&gt; 5;
// &#x7B49;&#x540C;&#x4E8E;
var f = function () { return 5 };

var sum = (num1, num2) =&gt; num1 + num2;
// &#x7B49;&#x540C;&#x4E8E;
var sum = function(num1, num2) {
  return num1 + num2;
};

// &#x51FD;&#x6570;&#x8FD4;&#x56DE;&#x4E00;&#x4E2A;&#x5BF9;&#x8C61;
let getTempItem = id =&gt; ({ id: id, name: &quot;Temp&quot; });
</code></pre>
<h3 id="&#x53CC;&#x5192;&#x53F7;&#x8FD0;&#x7B97;&#x7B26;"><a name="&#x53CC;&#x5192;&#x53F7;&#x8FD0;&#x7B97;&#x7B26;" class="anchor-navigation-ex-anchor" href="#&#x53CC;&#x5192;&#x53F7;&#x8FD0;&#x7B97;&#x7B26;"><i class="fa fa-link" aria-hidden="true"></i></a>1.9.4. &#x53CC;&#x5192;&#x53F7;&#x8FD0;&#x7B97;&#x7B26;</h3>
<p>&#x5728;JavaScript&#x4E2D;&#xFF0C;call&#x3001;apply&#x548C;bind&#x662F;Function&#x5BF9;&#x8C61;&#x81EA;&#x5E26;&#x7684;&#x4E09;&#x4E2A;&#x65B9;&#x6CD5;&#xFF0C;&#x8FD9;&#x4E09;&#x4E2A;&#x65B9;&#x6CD5;&#x7684;&#x4E3B;&#x8981;&#x4F5C;&#x7528;&#x662F;&#x6539;&#x53D8;&#x51FD;&#x6570;&#x4E2D;&#x7684;this&#x6307;&#x5411;&#x3002;</p>
<pre><code class="lang-xml">&#x53CC;&#x5192;&#x53F7;&#x5DE6;&#x8FB9;&#x662F;&#x4E00;&#x4E2A;&#x5BF9;&#x8C61;&#xFF0C;&#x53F3;&#x8FB9;&#x662F;&#x4E00;&#x4E2A;&#x51FD;&#x6570;&#x3002;&#x8BE5;&#x8FD0;&#x7B97;&#x7B26;&#x4F1A;&#x81EA;&#x52A8;&#x5C06;&#x5DE6;&#x8FB9;&#x7684;&#x5BF9;&#x8C61;&#xFF0C;&#x4F5C;&#x4E3A;&#x4E0A;&#x4E0B;&#x6587;&#x73AF;&#x5883;&#xFF08;&#x5373;this&#x5BF9;&#x8C61;&#xFF09;&#xFF0C;&#x7ED1;&#x5B9A;&#x5230;&#x53F3;&#x8FB9;&#x7684;&#x51FD;&#x6570;&#x4E0A;&#x9762;&#x3002;
foo::bar;
// &#x7B49;&#x540C;&#x4E8E;
bar.bind(foo);

foo::bar(...arguments);
// &#x7B49;&#x540C;&#x4E8E;
bar.apply(foo, arguments);
</code></pre>
<h2 id="&#x6570;&#x7EC4;&#x7684;&#x6269;&#x5C55;"><a name="&#x6570;&#x7EC4;&#x7684;&#x6269;&#x5C55;" class="anchor-navigation-ex-anchor" href="#&#x6570;&#x7EC4;&#x7684;&#x6269;&#x5C55;"><i class="fa fa-link" aria-hidden="true"></i></a>1.10. &#x6570;&#x7EC4;&#x7684;&#x6269;&#x5C55;</h2>
<h3 id="&#x6269;&#x5C55;&#x8FD0;&#x7B97;&#x7B26;-"><a name="&#x6269;&#x5C55;&#x8FD0;&#x7B97;&#x7B26;-" class="anchor-navigation-ex-anchor" href="#&#x6269;&#x5C55;&#x8FD0;&#x7B97;&#x7B26;-"><i class="fa fa-link" aria-hidden="true"></i></a>1.10.1. &#x6269;&#x5C55;&#x8FD0;&#x7B97;&#x7B26; ...</h3>
<p>&#x5C06;&#x4E00;&#x4E2A;&#x6570;&#x7EC4;&#x8F6C;&#x4E3A;&#x7528;&#x9017;&#x53F7;&#x5206;&#x9694;&#x7684;&#x53C2;&#x6570;&#x5E8F;&#x5217;&#x3002;</p>
<pre><code class="lang-xml">console.log(...[1, 2, 3]) // 1 2 3

// &#x590D;&#x5236;&#x6570;&#x7EC4; &#xFF0C;&#x5C5E;&#x4E8E;&#x6DF1;&#x5EA6;&#x590D;&#x5236;
const a1 = [1, 2];
const a2 = [...a1]; // &#x5199;&#x6CD5;&#x4E00;
const [...a2] = a1;// &#x5199;&#x6CD5;&#x4E8C;


// &#x5408;&#x5E76;&#x6570;&#x7EC4;
const arr1 = [&apos;a&apos;, &apos;b&apos;];
const arr2 = [&apos;c&apos;];
arr1.concat(arr2, arr3);// ES5 &#x7684;&#x5408;&#x5E76;&#x6570;&#x7EC4;
[...arr1, ...arr2, ...arr3] // ES6 &#x7684;&#x5408;&#x5E76;&#x6570;&#x7EC4;
</code></pre>
<h3 id="&#x6570;&#x7EC4;&#x76F8;&#x5173;&#x7684;&#x51FD;&#x6570;"><a name="&#x6570;&#x7EC4;&#x76F8;&#x5173;&#x7684;&#x51FD;&#x6570;" class="anchor-navigation-ex-anchor" href="#&#x6570;&#x7EC4;&#x76F8;&#x5173;&#x7684;&#x51FD;&#x6570;"><i class="fa fa-link" aria-hidden="true"></i></a>1.10.2. &#x6570;&#x7EC4;&#x76F8;&#x5173;&#x7684;&#x51FD;&#x6570;</h3>
<table>
<thead>
<tr>
<th>&#x540D;&#x5B57;</th>
<th>&#x8BF4;&#x660E;</th>
</tr>
</thead>
<tbody>
<tr>
<td>Array.from()</td>
<td>&#x7528;&#x4E8E;&#x5C06; &#x7C7B;&#x4F3C;&#x6570;&#x7EC4;&#x7684;&#x5BF9;&#x8C61; &#x548C;&#x53EF;&#x904D;&#x5386;&#x7684;&#x5BF9;&#x8C61;&#x8F6C;&#x4E3A;&#x771F;&#x6B63;&#x7684;&#x6570;&#x7EC4;</td>
</tr>
<tr>
<td>Array.of()</td>
<td>&#x7528;&#x4E8E;&#x5C06;&#x4E00;&#x7EC4;&#x503C;&#xFF0C;&#x8F6C;&#x6362;&#x4E3A;&#x6570;&#x7EC4;</td>
</tr>
<tr>
<td>copyWithin()</td>
<td>&#x5C06;&#x6307;&#x5B9A;&#x4F4D;&#x7F6E;&#x7684;&#x6210;&#x5458;&#x590D;&#x5236;&#x5230;&#x5176;&#x4ED6;&#x6307;&#x5B9A;&#x4F4D;&#x7F6E;&#xFF08;&#x8986;&#x76D6;&#x539F;&#x6709;&#x6210;&#x5458;&#xFF09;&#xFF0C;&#x7136;&#x540E;&#x8FD4;&#x56DE;&#x5F53;&#x524D;&#x6570;&#x7EC4;</td>
</tr>
<tr>
<td>find()</td>
<td>&#x7528;&#x4E8E;&#x627E;&#x51FA;&#x7B2C;&#x4E00;&#x4E2A;&#x7B26;&#x5408;&#x6761;&#x4EF6;&#x7684;&#x6570;&#x7EC4;&#x6210;&#x5458;</td>
</tr>
<tr>
<td>findIndex()</td>
<td>&#x8FD4;&#x56DE;&#x7B2C;&#x4E00;&#x4E2A;&#x7B26;&#x5408;&#x6761;&#x4EF6;&#x7684;&#x6570;&#x7EC4;&#x6210;&#x5458;&#x7684;&#x4F4D;&#x7F6E;</td>
</tr>
<tr>
<td>fill()</td>
<td>&#x4F7F;&#x7528;&#x7ED9;&#x5B9A;&#x503C;&#xFF0C;&#x586B;&#x5145;&#x4E00;&#x4E2A;&#x6570;&#x7EC4;</td>
</tr>
<tr>
<td>entries()</td>
<td>&#x5BF9;&#x952E;&#x503C;&#x5BF9; &#x904D;&#x5386;</td>
</tr>
<tr>
<td>keys()</td>
<td>&#x5BF9;&#x952E;&#x540D; &#x904D;&#x5386;</td>
</tr>
<tr>
<td>values()</td>
<td>&#x5BF9;&#x952E;&#x503C; &#x904D;&#x5386;</td>
</tr>
<tr>
<td>includes()</td>
<td>&#x8868;&#x793A;&#x67D0;&#x4E2A;&#x6570;&#x7EC4;&#x662F;&#x5426;&#x5305;&#x542B;&#x7ED9;&#x5B9A;&#x7684;&#x503C;</td>
</tr>
<tr>
<td>flat()</td>
<td>&#x5C06;&#x5D4C;&#x5957;&#x7684;&#x6570;&#x7EC4;&#x201C;&#x62C9;&#x5E73;&#x201D;&#xFF0C;&#x53D8;&#x6210;&#x4E00;&#x7EF4;&#x7684;&#x6570;&#x7EC4;&#x3002; &#x8FD4;&#x56DE;&#x4E00;&#x4E2A;&#x65B0;&#x6570;&#x7EC4;</td>
</tr>
<tr>
<td>flatMap()</td>
<td>&#x5BF9;&#x539F;&#x6570;&#x7EC4;&#x7684;&#x6BCF;&#x4E2A;&#x6210;&#x5458;&#x6267;&#x884C;&#x4E00;&#x4E2A;&#x6307;&#x5B9A;&#x51FD;&#x6570; &#xFF0C;&#x7136;&#x540E;&#x5BF9;&#x8FD4;&#x56DE;&#x503C;&#x7EC4;&#x6210;&#x7684;&#x6570;&#x7EC4;&#x6267;&#x884C;flat()&#x65B9;&#x6CD5;</td>
</tr>
<tr>
<td>Array(n)</td>
<td>&#x8FD4;&#x56DE;&#x4E00;&#x4E2A;&#x5177;&#x6709; n &#x4E2A;&#x7A7A;&#x4F4D;&#x7684;&#x6570;&#x7EC4;</td>
</tr>
</tbody>
</table>
<h2 id="&#x5BF9;&#x8C61;&#x7684;&#x6269;&#x5C55;"><a name="&#x5BF9;&#x8C61;&#x7684;&#x6269;&#x5C55;" class="anchor-navigation-ex-anchor" href="#&#x5BF9;&#x8C61;&#x7684;&#x6269;&#x5C55;"><i class="fa fa-link" aria-hidden="true"></i></a>1.11. &#x5BF9;&#x8C61;&#x7684;&#x6269;&#x5C55;</h2>
<h3 id="&#x5C5E;&#x6027;&#x7684;&#x7B80;&#x6D01;&#x8868;&#x793A;"><a name="&#x5C5E;&#x6027;&#x7684;&#x7B80;&#x6D01;&#x8868;&#x793A;" class="anchor-navigation-ex-anchor" href="#&#x5C5E;&#x6027;&#x7684;&#x7B80;&#x6D01;&#x8868;&#x793A;"><i class="fa fa-link" aria-hidden="true"></i></a>1.11.1. &#x5C5E;&#x6027;&#x7684;&#x7B80;&#x6D01;&#x8868;&#x793A;</h3>
<pre><code class="lang-xml">function f(x, y) {
  return {x, y};
}

// &#x7B49;&#x540C;&#x4E8E;
function f(x, y) {
  return {x: x, y: y};
}
</code></pre>
<h3 id="&#x65B9;&#x6CD5;&#x7684;&#x7B80;&#x6D01;&#x8868;&#x793A;"><a name="&#x65B9;&#x6CD5;&#x7684;&#x7B80;&#x6D01;&#x8868;&#x793A;" class="anchor-navigation-ex-anchor" href="#&#x65B9;&#x6CD5;&#x7684;&#x7B80;&#x6D01;&#x8868;&#x793A;"><i class="fa fa-link" aria-hidden="true"></i></a>1.11.2. &#x65B9;&#x6CD5;&#x7684;&#x7B80;&#x6D01;&#x8868;&#x793A;</h3>
<pre><code class="lang-xml">hello : function (){...}
// &#x7B49;&#x540C;&#x4E8E;
hello() { ... }
</code></pre>
<h3 id="&#x5BF9;&#x8C61;&#x76F8;&#x5173;&#x7684;&#x51FD;&#x6570;"><a name="&#x5BF9;&#x8C61;&#x76F8;&#x5173;&#x7684;&#x51FD;&#x6570;" class="anchor-navigation-ex-anchor" href="#&#x5BF9;&#x8C61;&#x76F8;&#x5173;&#x7684;&#x51FD;&#x6570;"><i class="fa fa-link" aria-hidden="true"></i></a>1.11.3. &#x5BF9;&#x8C61;&#x76F8;&#x5173;&#x7684;&#x51FD;&#x6570;</h3>
<table>
<thead>
<tr>
<th>&#x540D;&#x5B57;</th>
<th>&#x8BF4;&#x660E;</th>
</tr>
</thead>
<tbody>
<tr>
<td>Object.is()</td>
<td>&#x4E0E;&#x4E25;&#x683C;&#x6BD4;&#x8F83;&#x8FD0;&#x7B97;&#x7B26;&#xFF08;===&#xFF09;&#x7684;&#x884C;&#x4E3A;&#x57FA;&#x672C;&#x4E00;&#x81F4; &#x3002;</td>
</tr>
<tr>
<td>Object.assign()</td>
<td>&#x7528;&#x4E8E;&#x5BF9;&#x8C61;&#x7684;&#x5408;&#x5E76;&#xFF0C;&#x5C06;&#x6E90;&#x5BF9;&#x8C61; &#x7684;&#x6240;&#x6709;&#x53EF;&#x679A;&#x4E3E;&#x5C5E;&#x6027;&#xFF0C;&#x590D;&#x5236;&#x5230;&#x76EE;&#x6807;&#x5BF9;&#x8C61;  &#x3002; <br> &#x5B9E;&#x884C;&#x7684;&#x662F;&#x6D45;&#x62F7;&#x8D1D; <br>  &#x9047;&#x5230;&#x540C;&#x540D;&#x5C5E;&#x6027;&#xFF0C; &#x5C06;&#x4F1A;&#x66FF;&#x6362;&#x3002;</td>
</tr>
<tr>
<td>Object.getOwnPropertyDescriptors(xx)</td>
<td>&#x4F1A;&#x8FD4;&#x56DE;&#x67D0;&#x4E2A;&#x5BF9;&#x8C61;&#x5C5E;&#x6027;&#x7684;&#x63CF;&#x8FF0;&#x5BF9;&#x8C61;</td>
</tr>
<tr>
<td>Object.setPrototypeOf()</td>
<td>&#x8BBE;&#x7F6E;&#x4E00;&#x4E2A;&#x5BF9;&#x8C61;&#x7684;prototype&#x5BF9;&#x8C61;&#xFF0C;&#x8FD4;&#x56DE;&#x53C2;&#x6570;&#x5BF9;&#x8C61;&#x672C;&#x8EAB;</td>
</tr>
<tr>
<td>Object.getPrototypeOf()</td>
<td>&#x8BFB;&#x53D6;&#x4E00;&#x4E2A;&#x5BF9;&#x8C61;&#x7684;&#x539F;&#x578B;&#x5BF9;&#x8C61;</td>
</tr>
<tr>
<td>Object.keys()</td>
<td>&#x8FD4;&#x56DE;&#x4E00;&#x4E2A;&#x6570;&#x7EC4;&#xFF0C;&#x6210;&#x5458;&#x662F;&#x53C2;&#x6570;&#x5BF9;&#x8C61;&#x81EA;&#x8EAB;&#x7684;&#xFF08;&#x4E0D;&#x542B;&#x7EE7;&#x627F;&#x7684;&#xFF09;&#x6240;&#x6709;&#x53EF;&#x904D;&#x5386; &#x5C5E;&#x6027;&#x7684;&#x952E;&#x540D;&#x3002;</td>
</tr>
<tr>
<td>Object.values()</td>
<td>&#x8FD4;&#x56DE;&#x4E00;&#x4E2A;&#x6570;&#x7EC4;&#xFF0C;&#x6210;&#x5458;&#x662F;&#x53C2;&#x6570;&#x5BF9;&#x8C61;&#x81EA;&#x8EAB;&#x7684;&#xFF08;&#x4E0D;&#x542B;&#x7EE7;&#x627F;&#x7684;&#xFF09;&#x6240;&#x6709;&#x53EF;&#x904D;&#x5386; &#x5C5E;&#x6027;&#x7684;&#x952E;&#x503C;&#x3002;</td>
</tr>
<tr>
<td>Object.entries()</td>
<td>&#x8FD4;&#x56DE;&#x4E00;&#x4E2A;&#x6570;&#x7EC4;&#xFF0C;&#x6210;&#x5458;&#x662F;&#x53C2;&#x6570;&#x5BF9;&#x8C61;&#x81EA;&#x8EAB;&#x7684;&#xFF08;&#x4E0D;&#x542B;&#x7EE7;&#x627F;&#x7684;&#xFF09;&#x6240;&#x6709;&#x53EF;&#x904D;&#x5386; &#x5C5E;&#x6027;&#x7684;&#x952E;&#x503C;&#x5BF9;&#x6570;&#x7EC4;&#x3002;</td>
</tr>
</tbody>
</table>
<h3 id="&#x904D;&#x5386;&#x5BF9;&#x8C61;&#x7684;&#x5C5E;&#x6027;"><a name="&#x904D;&#x5386;&#x5BF9;&#x8C61;&#x7684;&#x5C5E;&#x6027;" class="anchor-navigation-ex-anchor" href="#&#x904D;&#x5386;&#x5BF9;&#x8C61;&#x7684;&#x5C5E;&#x6027;"><i class="fa fa-link" aria-hidden="true"></i></a>1.11.4. &#x904D;&#x5386;&#x5BF9;&#x8C61;&#x7684;&#x5C5E;&#x6027;</h3>
<pre><code class="lang-xml">1&#x3001;for...in
&#x5FAA;&#x73AF;&#x904D;&#x5386;&#x5BF9;&#x8C61;&#x81EA;&#x8EAB;&#x7684;&#x548C;&#x7EE7;&#x627F;&#x7684;&#x53EF;&#x679A;&#x4E3E;&#x5C5E;&#x6027;&#xFF08;&#x4E0D;&#x542B; Symbol &#x5C5E;&#x6027;&#xFF09;&#x3002;

2&#x3001;Object.keys(obj)
&#x8FD4;&#x56DE;&#x4E00;&#x4E2A;&#x6570;&#x7EC4;&#xFF0C;&#x5305;&#x62EC;&#x5BF9;&#x8C61;&#x81EA;&#x8EAB;&#x7684;&#xFF08;&#x4E0D;&#x542B;&#x7EE7;&#x627F;&#x7684;&#xFF09;&#x6240;&#x6709;&#x53EF;&#x679A;&#x4E3E;&#x5C5E;&#x6027;&#xFF08;&#x4E0D;&#x542B; Symbol &#x5C5E;&#x6027;&#xFF09;&#x7684;&#x952E;&#x540D;&#x3002;

3&#x3001;Object.getOwnPropertyNames(obj)
&#x8FD4;&#x56DE;&#x4E00;&#x4E2A;&#x6570;&#x7EC4;&#xFF0C;&#x5305;&#x542B;&#x5BF9;&#x8C61;&#x81EA;&#x8EAB;&#x7684;&#x6240;&#x6709;&#x5C5E;&#x6027;&#xFF08;&#x4E0D;&#x542B; Symbol &#x5C5E;&#x6027;&#xFF0C;&#x4F46;&#x662F;&#x5305;&#x62EC;&#x4E0D;&#x53EF;&#x679A;&#x4E3E;&#x5C5E;&#x6027;&#xFF09;&#x7684;&#x952E;&#x540D;&#x3002;

4&#x3001;Object.getOwnPropertySymbols(obj)
&#x8FD4;&#x56DE;&#x4E00;&#x4E2A;&#x6570;&#x7EC4;&#xFF0C;&#x5305;&#x542B;&#x5BF9;&#x8C61;&#x81EA;&#x8EAB;&#x7684;&#x6240;&#x6709; Symbol &#x5C5E;&#x6027;&#x7684;&#x952E;&#x540D;&#x3002;

5&#x3001;Reflect.ownKeys(obj)
&#x8FD4;&#x56DE;&#x4E00;&#x4E2A;&#x6570;&#x7EC4;&#xFF0C;&#x5305;&#x542B;&#x5BF9;&#x8C61;&#x81EA;&#x8EAB;&#x7684;&#x6240;&#x6709;&#x952E;&#x540D;&#xFF0C;&#x4E0D;&#x7BA1;&#x952E;&#x540D;&#x662F; Symbol &#x6216;&#x5B57;&#x7B26;&#x4E32;&#xFF0C;&#x4E5F;&#x4E0D;&#x7BA1;&#x662F;&#x5426;&#x53EF;&#x679A;&#x4E3E;&#x3002;
</code></pre>
<h3 id="super-&#x5173;&#x952E;&#x5B57;"><a name="super-&#x5173;&#x952E;&#x5B57;" class="anchor-navigation-ex-anchor" href="#super-&#x5173;&#x952E;&#x5B57;"><i class="fa fa-link" aria-hidden="true"></i></a>1.11.5. super &#x5173;&#x952E;&#x5B57;</h3>
<p>this&#x5173;&#x952E;&#x5B57;&#x603B;&#x662F;&#x6307;&#x5411;&#x51FD;&#x6570;&#x6240;&#x5728;&#x7684;&#x5F53;&#x524D;&#x5BF9;&#x8C61; &#x3002;
ES6 &#x65B0;&#x589E;&#x4E86;&#x5173;&#x952E;&#x5B57;super&#xFF0C;&#x6307;&#x5411;&#x5F53;&#x524D;&#x5BF9;&#x8C61;&#x7684;&#x539F;&#x578B;&#x5BF9;&#x8C61;&#x3002;</p>
<pre><code class="lang-xml">```

## Symbol  &#x539F;&#x59CB;&#x6570;&#x636E;&#x7C7B;&#x578B;
ES6 &#x5F15;&#x5165;&#x4E86;&#x4E00;&#x79CD;&#x65B0;&#x7684;&#x539F;&#x59CB;&#x6570;&#x636E;&#x7C7B;&#x578B;Symbol&#xFF0C;&#x8868;&#x793A;&#x72EC;&#x4E00;&#x65E0;&#x4E8C;&#x7684;&#x503C;&#x3002;
```xml
Symbol &#x503C;&#x901A;&#x8FC7;Symbol&#x51FD;&#x6570;&#x751F;&#x6210;&#x3002;
&#x51E1;&#x662F;&#x5C5E;&#x6027;&#x540D;&#x5C5E;&#x4E8E; Symbol &#x7C7B;&#x578B;&#xFF0C;&#x5C31;&#x90FD;&#x662F;&#x72EC;&#x4E00;&#x65E0;&#x4E8C;&#x7684;&#xFF0C;&#x53EF;&#x4EE5;&#x4FDD;&#x8BC1;&#x4E0D;&#x4F1A;&#x4E0E;&#x5176;&#x4ED6;&#x5C5E;&#x6027;&#x540D;&#x4EA7;&#x751F;&#x51B2;&#x7A81;&#x3002;

let s1 = Symbol(&apos;foo&apos;);
</code></pre>
<h3 id="symbol&#x76F8;&#x5173;&#x7684;&#x51FD;&#x6570;&#x3001;&#x5C5E;&#x6027;"><a name="symbol&#x76F8;&#x5173;&#x7684;&#x51FD;&#x6570;&#x3001;&#x5C5E;&#x6027;" class="anchor-navigation-ex-anchor" href="#symbol&#x76F8;&#x5173;&#x7684;&#x51FD;&#x6570;&#x3001;&#x5C5E;&#x6027;"><i class="fa fa-link" aria-hidden="true"></i></a>1.11.6. Symbol&#x76F8;&#x5173;&#x7684;&#x51FD;&#x6570;&#x3001;&#x5C5E;&#x6027;</h3>
<table>
<thead>
<tr>
<th>&#x540D;&#x5B57;</th>
<th>&#x8BF4;&#x660E;</th>
</tr>
</thead>
<tbody>
<tr>
<td>Symbol.for()</td>
<td>Symbol &#x503C;&#x767B;&#x8BB0;&#x7684;&#x540D;&#x5B57;&#xFF0C;&#x662F;&#x5168;&#x5C40;&#x73AF;&#x5883;&#x7684;&#xFF0C;&#x53EF;&#x4EE5;&#x5728;&#x4E0D;&#x540C;&#x7684; iframe &#x6216; service worker &#x4E2D;&#x53D6;&#x5230;&#x540C;&#x4E00;&#x4E2A;&#x503C;&#x3002;</td>
</tr>
<tr>
<td>Symbol.keyFor()</td>
<td>&#x8FD4;&#x56DE;&#x4E00;&#x4E2A;&#x5DF2;&#x767B;&#x8BB0;&#x7684; Symbol &#x7C7B;&#x578B;&#x503C;&#x7684;key</td>
</tr>
<tr>
<td>Symbol.hasInstance</td>
<td>&#x5F53;&#x5176;&#x4ED6;&#x5BF9;&#x8C61;&#x4F7F;&#x7528;instanceof&#x8FD0;&#x7B97;&#x7B26;&#xFF0C;&#x5224;&#x65AD;&#x662F;&#x5426;&#x4E3A;&#x8BE5;&#x5BF9;&#x8C61;&#x7684;&#x5B9E;&#x4F8B;&#x65F6;&#xFF0C;&#x4F1A;&#x8C03;&#x7528;&#x8FD9;&#x4E2A;&#x65B9;&#x6CD5;</td>
</tr>
<tr>
<td>Symbol.isConcatSpreadable</td>
<td>&#x8868;&#x793A;&#x8BE5;&#x5BF9;&#x8C61;&#x7528;&#x4E8E;Array.prototype.concat()&#x65F6;&#xFF0C;&#x662F;&#x5426;&#x53EF;&#x4EE5;&#x5C55;&#x5F00;&#x3002;</td>
</tr>
<tr>
<td>Symbol.species</td>
<td>&#x521B;&#x5EFA;&#x884D;&#x751F;&#x5BF9;&#x8C61;&#x65F6;&#xFF0C;&#x4F1A;&#x4F7F;&#x7528;&#x8BE5;&#x5C5E;&#x6027;</td>
</tr>
<tr>
<td>Symbol.match</td>
<td>&#x5F53;&#x6267;&#x884C;str.match(myObject)&#x65F6;&#xFF0C;&#x5982;&#x679C;&#x8BE5;&#x5C5E;&#x6027;&#x5B58;&#x5728;&#xFF0C;&#x4F1A;&#x8C03;&#x7528;&#x5B83;&#xFF0C;&#x8FD4;&#x56DE;&#x8BE5;&#x65B9;&#x6CD5;&#x7684;&#x8FD4;&#x56DE;&#x503C;&#x3002;</td>
</tr>
<tr>
<td>Symbol.replace</td>
<td>&#x5F53;&#x8BE5;&#x5BF9;&#x8C61;&#x88AB;String.prototype.replace&#x65B9;&#x6CD5;&#x8C03;&#x7528;&#x65F6;&#xFF0C;&#x4F1A;&#x8FD4;&#x56DE;&#x8BE5;&#x65B9;&#x6CD5;&#x7684;&#x8FD4;&#x56DE;&#x503C;&#x3002;</td>
</tr>
<tr>
<td>Symbol.search</td>
<td>&#x5F53;&#x8BE5;&#x5BF9;&#x8C61;&#x88AB;String.prototype.search&#x65B9;&#x6CD5;&#x8C03;&#x7528;&#x65F6;&#xFF0C;&#x4F1A;&#x8FD4;&#x56DE;&#x8BE5;&#x65B9;&#x6CD5;&#x7684;&#x8FD4;&#x56DE;&#x503C;&#x3002;</td>
</tr>
<tr>
<td>Symbol.split</td>
<td>&#x5F53;&#x8BE5;&#x5BF9;&#x8C61;&#x88AB;String.prototype.split&#x65B9;&#x6CD5;&#x8C03;&#x7528;&#x65F6;&#xFF0C;&#x4F1A;&#x8FD4;&#x56DE;&#x8BE5;&#x65B9;&#x6CD5;&#x7684;&#x8FD4;&#x56DE;&#x503C;&#x3002;</td>
</tr>
<tr>
<td>Symbol.iterator</td>
<td>&#x6307;&#x5411;&#x8BE5;&#x5BF9;&#x8C61;&#x7684;&#x9ED8;&#x8BA4;&#x904D;&#x5386;&#x5668;&#x65B9;&#x6CD5;</td>
</tr>
<tr>
<td>Symbol.toPrimitive</td>
<td>&#x8BE5;&#x5BF9;&#x8C61;&#x88AB;&#x8F6C;&#x4E3A;&#x539F;&#x59CB;&#x7C7B;&#x578B;&#x7684;&#x503C;&#x65F6;&#xFF0C;&#x4F1A;&#x8C03;&#x7528;&#x8FD9;&#x4E2A;&#x65B9;&#x6CD5;&#xFF0C;&#x8FD4;&#x56DE;&#x8BE5;&#x5BF9;&#x8C61;&#x5BF9;&#x5E94;&#x7684;&#x539F;&#x59CB;&#x7C7B;&#x578B;&#x503C;&#x3002;</td>
</tr>
<tr>
<td>Symbol.toStringTag</td>
<td>&#x8FD9;&#x4E2A;&#x5C5E;&#x6027;&#x53EF;&#x4EE5;&#x7528;&#x6765;&#x5B9A;&#x5236;[object Object]&#x6216;[object Array]&#x4E2D;object&#x540E;&#x9762;&#x7684;&#x90A3;&#x4E2A;&#x5B57;&#x7B26;&#x4E32;</td>
</tr>
<tr>
<td>Symbol.unscopables</td>
<td>&#x8BE5;&#x5BF9;&#x8C61;&#x6307;&#x5B9A;&#x4E86;&#x4F7F;&#x7528;with&#x5173;&#x952E;&#x5B57;&#x65F6;&#xFF0C;&#x54EA;&#x4E9B;&#x5C5E;&#x6027;&#x4F1A;&#x88AB;with&#x73AF;&#x5883;&#x6392;&#x9664;&#x3002;</td>
</tr>
</tbody>
</table>
<h2 id="set--&#x6570;&#x636E;&#x7ED3;&#x6784;"><a name="set--&#x6570;&#x636E;&#x7ED3;&#x6784;" class="anchor-navigation-ex-anchor" href="#set--&#x6570;&#x636E;&#x7ED3;&#x6784;"><i class="fa fa-link" aria-hidden="true"></i></a>1.12. Set  &#x6570;&#x636E;&#x7ED3;&#x6784;</h2>
<p>ES6 &#x65B0;&#x589E;&#x4E86; Set&#x3002;</p>
<h2 id="weakset-&#x6570;&#x636E;&#x7ED3;&#x6784;"><a name="weakset-&#x6570;&#x636E;&#x7ED3;&#x6784;" class="anchor-navigation-ex-anchor" href="#weakset-&#x6570;&#x636E;&#x7ED3;&#x6784;"><i class="fa fa-link" aria-hidden="true"></i></a>1.13. WeakSet &#x6570;&#x636E;&#x7ED3;&#x6784;</h2>
<p>WeakSet &#x7ED3;&#x6784;&#x4E0E; Set &#x7C7B;&#x4F3C; &#x3002;</p>
<pre><code class="lang-xml">WeakSet &#x7684;&#x6210;&#x5458;&#x53EA;&#x80FD;&#x662F;&#x5BF9;&#x8C61;&#xFF0C;&#x800C;&#x4E0D;&#x80FD;&#x662F;&#x5176;&#x4ED6;&#x7C7B;&#x578B;&#x7684;&#x503C;&#x3002;
WeakSet &#x4E2D;&#x7684;&#x5BF9;&#x8C61;&#x90FD;&#x662F;&#x5F31;&#x5F15;&#x7528;&#x3002;// WeakSet &#x7684;&#x6210;&#x5458;&#x662F;&#x4E0D;&#x9002;&#x5408;&#x5F15;&#x7528;&#x7684;&#xFF0C;&#x56E0;&#x4E3A;&#x5B83;&#x4F1A;&#x968F;&#x65F6;&#x6D88;&#x5931;&#x3002;
</code></pre>
<h2 id="map-&#x6570;&#x636E;&#x7ED3;&#x6784;"><a name="map-&#x6570;&#x636E;&#x7ED3;&#x6784;" class="anchor-navigation-ex-anchor" href="#map-&#x6570;&#x636E;&#x7ED3;&#x6784;"><i class="fa fa-link" aria-hidden="true"></i></a>1.14. Map &#x6570;&#x636E;&#x7ED3;&#x6784;</h2>
<p>ES6 &#x65B0;&#x589E;&#x4E86;Map &#x3002;</p>
<pre><code class="lang-xml">function strMapToObj(strMap) {
  let obj = Object.create(null);
  for (let [k,v] of strMap) {
    obj[k] = v;
  }
  return obj;
}

// Map &#x8F6C;&#x4E3A; JSON
let myMap = new Map().set(&apos;yes&apos;, true).set(&apos;no&apos;, false);
JSON.stringify(strMapToObj(myMap));

// JSON &#x8F6C;&#x4E3A; Map   
function objToStrMap(obj) {
  let strMap = new Map();
  for (let k of Object.keys(obj)) {
    strMap.set(k, obj[k]);
  }
  return strMap;
}
JSON.parse(&apos;{&quot;yes&quot;: true, &quot;no&quot;: false}&apos;)
</code></pre>
<h2 id="weakmap-&#x6570;&#x636E;&#x7ED3;&#x6784;"><a name="weakmap-&#x6570;&#x636E;&#x7ED3;&#x6784;" class="anchor-navigation-ex-anchor" href="#weakmap-&#x6570;&#x636E;&#x7ED3;&#x6784;"><i class="fa fa-link" aria-hidden="true"></i></a>1.15. WeakMap &#x6570;&#x636E;&#x7ED3;&#x6784;</h2>
<pre><code class="lang-xml">&#x53EA;&#x63A5;&#x53D7;&#x5BF9;&#x8C61;&#x4F5C;&#x4E3A;&#x952E;&#x540D;&#xFF08;null&#x9664;&#x5916;&#xFF09;&#xFF0C;&#x4E0D;&#x63A5;&#x53D7;&#x5176;&#x4ED6;&#x7C7B;&#x578B;&#x7684;&#x503C;&#x4F5C;&#x4E3A;&#x952E;&#x540D;&#x3002;

WeakMap&#x7684;&#x952E;&#x540D;&#x6240;&#x6307;&#x5411;&#x7684;&#x5BF9;&#x8C61;&#xFF0C;&#x4E0D;&#x8BA1;&#x5165;&#x5783;&#x573E;&#x56DE;&#x6536;&#x673A;&#x5236;&#x3002;
WeakMap &#x5F31;&#x5F15;&#x7528;&#x7684;&#x53EA;&#x662F;&#x952E;&#x540D;&#xFF0C;&#x800C;&#x4E0D;&#x662F;&#x952E;&#x503C;&#x3002;&#x952E;&#x503C;&#x4F9D;&#x7136;&#x662F;&#x6B63;&#x5E38;&#x5F15;&#x7528;&#x3002;
</code></pre>
<h2 id="proxy-&#x4EE3;&#x7406;&#x5668;"><a name="proxy-&#x4EE3;&#x7406;&#x5668;" class="anchor-navigation-ex-anchor" href="#proxy-&#x4EE3;&#x7406;&#x5668;"><i class="fa fa-link" aria-hidden="true"></i></a>1.16. Proxy &#x4EE3;&#x7406;&#x5668;</h2>
<pre><code class="lang-xml">&#x53EF;&#x4EE5;&#x7406;&#x89E3;&#x6210;&#xFF0C;&#x5728;&#x76EE;&#x6807;&#x5BF9;&#x8C61;&#x4E4B;&#x524D;&#x67B6;&#x8BBE;&#x4E00;&#x5C42;&#x201C;&#x62E6;&#x622A;&#x201D;&#xFF0C;
&#x5916;&#x754C;&#x5BF9;&#x8BE5;&#x5BF9;&#x8C61;&#x7684;&#x8BBF;&#x95EE;&#xFF0C;&#x90FD;&#x5FC5;&#x987B;&#x5148;&#x901A;&#x8FC7;&#x8FD9;&#x5C42;&#x62E6;&#x622A;&#xFF0C;
&#x56E0;&#x6B64;&#x63D0;&#x4F9B;&#x4E86;&#x4E00;&#x79CD;&#x673A;&#x5236;&#xFF0C;&#x53EF;&#x4EE5;&#x5BF9;&#x5916;&#x754C;&#x7684;&#x8BBF;&#x95EE;&#x8FDB;&#x884C;&#x8FC7;&#x6EE4;&#x548C;&#x6539;&#x5199;&#x3002;
</code></pre>
<h3 id="proxy&#x652F;&#x6301;&#x7684;&#x62E6;&#x622A;&#x64CD;&#x4F5C;"><a name="proxy&#x652F;&#x6301;&#x7684;&#x62E6;&#x622A;&#x64CD;&#x4F5C;" class="anchor-navigation-ex-anchor" href="#proxy&#x652F;&#x6301;&#x7684;&#x62E6;&#x622A;&#x64CD;&#x4F5C;"><i class="fa fa-link" aria-hidden="true"></i></a>1.16.1. Proxy&#x652F;&#x6301;&#x7684;&#x62E6;&#x622A;&#x64CD;&#x4F5C;</h3>
<table>
<thead>
<tr>
<th>&#x7C7B;&#x578B;</th>
<th>&#x8BF4;&#x660E;</th>
</tr>
</thead>
<tbody>
<tr>
<td>get</td>
<td>&#x62E6;&#x622A;&#x5BF9;&#x8C61;&#x5C5E;&#x6027;&#x7684;&#x8BFB;&#x53D6;</td>
</tr>
<tr>
<td>set</td>
<td>&#x62E6;&#x622A;&#x5BF9;&#x8C61;&#x5C5E;&#x6027;&#x7684;&#x8BBE;&#x7F6E;</td>
</tr>
<tr>
<td>has</td>
<td>&#x62E6;&#x622A;propKey in proxy&#x7684;&#x64CD;&#x4F5C;</td>
</tr>
<tr>
<td>deleteProperty</td>
<td>&#x62E6;&#x622A;delete proxy[propKey]&#x7684;&#x64CD;&#x4F5C;</td>
</tr>
<tr>
<td>ownKeys</td>
<td>&#x62E6;&#x622A;Object.getOwnPropertyNames(proxy)&#x3001;Object.getOwnPropertySymbols(proxy)&#x3001;Object.keys(proxy)&#x3001;for...in&#x5FAA;&#x73AF;</td>
</tr>
<tr>
<td>getOwnPropertyDescriptor</td>
<td>&#x62E6;&#x622A;Object.getOwnPropertyDescriptor(proxy, propKey)</td>
</tr>
<tr>
<td>defineProperty</td>
<td>&#x62E6;&#x622A;Object.defineProperty(proxy, propKey, propDesc&#xFF09;&#x3001;Object.defineProperties(proxy, propDescs)</td>
</tr>
<tr>
<td>preventExtensions</td>
<td>&#x62E6;&#x622A;Object.preventExtensions(proxy)</td>
</tr>
<tr>
<td>getPrototypeOf</td>
<td>&#x62E6;&#x622A;Object.getPrototypeOf(proxy)</td>
</tr>
<tr>
<td>isExtensible</td>
<td>&#x62E6;&#x622A;Object.isExtensible(proxy)</td>
</tr>
<tr>
<td>setPrototypeOf</td>
<td>&#x62E6;&#x622A;Object.setPrototypeOf(proxy, proto)</td>
</tr>
<tr>
<td>apply</td>
<td>&#x62E6;&#x622A; Proxy &#x5B9E;&#x4F8B;&#x4F5C;&#x4E3A;&#x51FD;&#x6570;&#x8C03;&#x7528;&#x7684;&#x64CD;&#x4F5C;</td>
</tr>
<tr>
<td>construct</td>
<td>&#x62E6;&#x622A; Proxy &#x5B9E;&#x4F8B;&#x4F5C;&#x4E3A;&#x6784;&#x9020;&#x51FD;&#x6570;&#x8C03;&#x7528;&#x7684;&#x64CD;&#x4F5C;</td>
</tr>
</tbody>
</table>
<h3 id="reflect-&#x53CD;&#x5C04;"><a name="reflect-&#x53CD;&#x5C04;" class="anchor-navigation-ex-anchor" href="#reflect-&#x53CD;&#x5C04;"><i class="fa fa-link" aria-hidden="true"></i></a>1.16.2. Reflect &#x53CD;&#x5C04;</h3>
<p>&#x4ECE;Reflect&#x5BF9;&#x8C61;&#x4E0A;&#x53EF;&#x4EE5;&#x62FF;&#x5230;&#x8BED;&#x8A00;&#x5185;&#x90E8;&#x7684;&#x65B9;&#x6CD5;&#x3002;</p>
<h3 id="reflect&#x5BF9;&#x8C61;&#x7684;&#x65B9;&#x6CD5;"><a name="reflect&#x5BF9;&#x8C61;&#x7684;&#x65B9;&#x6CD5;" class="anchor-navigation-ex-anchor" href="#reflect&#x5BF9;&#x8C61;&#x7684;&#x65B9;&#x6CD5;"><i class="fa fa-link" aria-hidden="true"></i></a>1.16.3. Reflect&#x5BF9;&#x8C61;&#x7684;&#x65B9;&#x6CD5;</h3>
<table>
<thead>
<tr>
<th>&#x540D;&#x5B57;</th>
<th>&#x8BF4;&#x660E;</th>
</tr>
</thead>
<tbody>
<tr>
<td>Reflect.apply(target, thisArg, args)</td>
<td>&#x7528;&#x4E8E;&#x7ED1;&#x5B9A;this&#x5BF9;&#x8C61;&#x540E;&#x6267;&#x884C;&#x7ED9;&#x5B9A;&#x51FD;&#x6570;</td>
</tr>
<tr>
<td>Reflect.construct(target, args)</td>
<td>&#x7B49;&#x540C;&#x4E8E;new target(...args)</td>
</tr>
<tr>
<td>Reflect.get(target, name, receiver)</td>
<td>&#x67E5;&#x627E;&#x5E76;&#x8FD4;&#x56DE;target&#x5BF9;&#x8C61;&#x7684;name&#x5C5E;&#x6027;</td>
</tr>
<tr>
<td>Reflect.set(target, name, value, receiver)</td>
<td>&#x8BBE;&#x7F6E;target&#x5BF9;&#x8C61;&#x7684;name&#x5C5E;&#x6027;&#x7B49;&#x4E8E;value&#x3002;</td>
</tr>
<tr>
<td>Reflect.defineProperty(target, name, desc)</td>
<td>&#x7528;&#x6765;&#x4E3A;&#x5BF9;&#x8C61;&#x5B9A;&#x4E49;&#x5C5E;&#x6027;&#x3002;</td>
</tr>
<tr>
<td>Reflect.deleteProperty(target, name)</td>
<td>&#x6CD5;&#x7B49;&#x540C;&#x4E8E;delete obj[name]&#xFF0C;&#x7528;&#x4E8E;&#x5220;&#x9664;&#x5BF9;&#x8C61;&#x7684;&#x5C5E;&#x6027;&#x3002;</td>
</tr>
<tr>
<td>Reflect.has(target, name)</td>
<td>&#x5BF9;&#x5E94;name in obj&#x91CC;&#x9762;&#x7684;in&#x8FD0;&#x7B97;&#x7B26;&#x3002;</td>
</tr>
<tr>
<td>Reflect.ownKeys(target)</td>
<td>&#x7528;&#x4E8E;&#x8FD4;&#x56DE;&#x5BF9;&#x8C61;&#x7684;&#x6240;&#x6709;&#x5C5E;&#x6027;</td>
</tr>
<tr>
<td>Reflect.isExtensible(target)</td>
<td>&#x8868;&#x793A;&#x5F53;&#x524D;&#x5BF9;&#x8C61;&#x662F;&#x5426;&#x53EF;&#x6269;&#x5C55;&#x3002;</td>
</tr>
<tr>
<td>Reflect.preventExtensions(target)</td>
<td>&#x7528;&#x4E8E;&#x8BA9;&#x4E00;&#x4E2A;&#x5BF9;&#x8C61;&#x53D8;&#x4E3A;&#x4E0D;&#x53EF;&#x6269;&#x5C55;&#x3002;</td>
</tr>
<tr>
<td>Reflect.getOwnPropertyDescriptor(target, name)</td>
<td>&#x7528;&#x4E8E;&#x5F97;&#x5230;&#x6307;&#x5B9A;&#x5C5E;&#x6027;&#x7684;&#x63CF;&#x8FF0;&#x5BF9;&#x8C61;</td>
</tr>
<tr>
<td>Reflect.getPrototypeOf(target)</td>
<td>&#x7528;&#x4E8E;&#x8BFB;&#x53D6;&#x5BF9;&#x8C61;&#x7684;<strong>proto</strong>&#x5C5E;&#x6027;</td>
</tr>
<tr>
<td>Reflect.setPrototypeOf(target, prototype)</td>
<td>&#x7528;&#x4E8E;&#x8BBE;&#x7F6E;&#x76EE;&#x6807;&#x5BF9;&#x8C61;&#x7684;&#x539F;&#x578B;&#xFF08;prototype&#xFF09;</td>
</tr>
</tbody>
</table>
<h2 id="promise"><a name="promise" class="anchor-navigation-ex-anchor" href="#promise"><i class="fa fa-link" aria-hidden="true"></i></a>1.17. Promise</h2>
<p>Promise &#x662F;&#x5F02;&#x6B65;&#x7F16;&#x7A0B;&#x7684;&#x4E00;&#x79CD;&#x89E3;&#x51B3;&#x65B9;&#x6848;</p>
<pre><code class="lang-JavaScript"><span class="hljs-built_in">Promise</span>&#x5BF9;&#x8C61;&#x53EF;&#x4EE5;&#x628A;&#x5F02;&#x6B65;&#x64CD;&#x4F5C;&#x4EE5;&#x540C;&#x6B65;&#x64CD;&#x4F5C;&#x7684;&#x6D41;&#x7A0B;&#x8868;&#x8FBE;&#x51FA;&#x6765;&#xFF0C;&#x907F;&#x514D;&#x4E86;&#x5C42;&#x5C42;&#x5D4C;&#x5957;&#x7684;&#x56DE;&#x8C03;&#x51FD;&#x6570;&#x3002;
Pending(&#x8FDB;&#x884C;&#x4E2D;)&#x3001;Resolved(&#x5DF2;&#x5B8C;&#x6210;)&#x3001;Rejected(&#x5DF2;&#x5931;&#x8D25;)

resolve &#x3001;reject &#x662F;&#x4E24;&#x4E2A;&#x7CFB;&#x7EDF;&#x51FD;&#x6570;

<span class="hljs-keyword">return</span> <span class="hljs-keyword">new</span> <span class="hljs-built_in">Promise</span>( (resolve, reject) =&gt; {
  loginByUsername(username, userInfo.password).then(response =&gt; {
     <span class="hljs-comment">// ok</span>
    resolve()
  }).catch(error =&gt; {
    reject(error)
  })
})
</code></pre>
<h3 id="promise-&#x5BF9;&#x8C61;&#x65B9;&#x6CD5;"><a name="promise-&#x5BF9;&#x8C61;&#x65B9;&#x6CD5;" class="anchor-navigation-ex-anchor" href="#promise-&#x5BF9;&#x8C61;&#x65B9;&#x6CD5;"><i class="fa fa-link" aria-hidden="true"></i></a>1.17.1. Promise &#x5BF9;&#x8C61;&#x65B9;&#x6CD5;</h3>
<table>
<thead>
<tr>
<th>&#x540D;&#x5B57;</th>
<th>&#x8BF4;&#x660E;</th>
</tr>
</thead>
<tbody>
<tr>
<td>then()</td>
<td>&#x4E3A; Promise &#x5B9E;&#x4F8B;&#x6DFB;&#x52A0;&#x72B6;&#x6001;&#x6539;&#x53D8;&#x65F6;&#x7684;&#x56DE;&#x8C03;&#x51FD;&#x6570;&#x3002; <br> &#x7B2C;&#x4E00;&#x4E2A;&#x53C2;&#x6570;&#x662F;resolved&#x72B6;&#x6001;&#x7684;&#x56DE;&#x8C03;&#x51FD;&#x6570;&#xFF0C; <br> &#x7B2C;&#x4E8C;&#x4E2A;&#x53C2;&#x6570;&#xFF08;&#x53EF;&#x9009;&#xFF09;&#x662F;rejected&#x72B6;&#x6001;&#x7684;&#x56DE;&#x8C03;&#x51FD;&#x6570;&#x3002;</td>
</tr>
<tr>
<td>catch()</td>
<td>&#x662F;.then(null, rejection)&#x7684;&#x522B;&#x540D;&#xFF0C;&#x7528;&#x4E8E;&#x6307;&#x5B9A;&#x53D1;&#x751F;&#x9519;&#x8BEF;&#x65F6;&#x7684;&#x56DE;&#x8C03;&#x51FD;&#x6570;&#x3002;</td>
</tr>
<tr>
<td>finally()</td>
<td>&#x6307;&#x5B9A;&#x4E0D;&#x7BA1; Promise &#x5BF9;&#x8C61;&#x6700;&#x540E;&#x72B6;&#x6001;&#x5982;&#x4F55;&#xFF0C;&#x90FD;&#x4F1A;&#x6267;&#x884C;&#x7684;&#x64CD;&#x4F5C;&#x3002;</td>
</tr>
<tr>
<td>Promise.all()</td>
<td>&#x5C06;&#x591A;&#x4E2A; Promise &#x5B9E;&#x4F8B;&#xFF0C;&#x5305;&#x88C5;&#x6210;&#x4E00;&#x4E2A;&#x65B0;&#x7684; Promise &#x5B9E;&#x4F8B;</td>
</tr>
<tr>
<td>Promise.race()</td>
<td>&#x5C06;&#x591A;&#x4E2A; Promise &#x5B9E;&#x4F8B;&#xFF0C;&#x5305;&#x88C5;&#x6210;&#x4E00;&#x4E2A;&#x65B0;&#x7684; Promise &#x5B9E;&#x4F8B;</td>
</tr>
<tr>
<td>Promise.resolve()</td>
<td>&#x5C06;&#x73B0;&#x6709;&#x5BF9;&#x8C61;&#x8F6C;&#x4E3A; Promise &#x5BF9;&#x8C61;</td>
</tr>
<tr>
<td>Promise.reject()</td>
<td>&#x5C06;&#x73B0;&#x6709;&#x5BF9;&#x8C61;&#x8F6C;&#x4E3A; Promise &#x5BF9;&#x8C61;</td>
</tr>
<tr>
<td>Promise.try()</td>
<td>&#x4E3A;&#x6240;&#x6709;&#x64CD;&#x4F5C;&#x63D0;&#x4F9B;&#x4E86;&#x7EDF;&#x4E00;&#x7684;&#x5904;&#x7406;&#x673A;&#x5236;&#xFF0C; &#x7528;Promise.try&#x5305;&#x88C5;&#x4E00;&#x4E0B;  </td>
</tr>
</tbody>
</table>
<h2 id="iterator-&#x904D;&#x5386;&#x5668;-&#x3001;&#x8FED;&#x4EE3;&#x5668;"><a name="iterator-&#x904D;&#x5386;&#x5668;-&#x3001;&#x8FED;&#x4EE3;&#x5668;" class="anchor-navigation-ex-anchor" href="#iterator-&#x904D;&#x5386;&#x5668;-&#x3001;&#x8FED;&#x4EE3;&#x5668;"><i class="fa fa-link" aria-hidden="true"></i></a>1.18. Iterator &#x904D;&#x5386;&#x5668; &#x3001;&#x8FED;&#x4EE3;&#x5668;</h2>
<p>&#x4EFB;&#x4F55;&#x6570;&#x636E;&#x7ED3;&#x6784;&#x53EA;&#x8981;&#x90E8;&#x7F72; Iterator &#x63A5;&#x53E3;&#xFF0C;&#x5C31;&#x53EF;&#x4EE5;&#x5B8C;&#x6210;&#x904D;&#x5386;&#x64CD;&#x4F5C; &#x3002;</p>
<pre><code class="lang-xml">&#x539F;&#x751F;&#x5177;&#x5907; Iterator &#x63A5;&#x53E3;&#x7684;&#x6570;&#x636E;&#x7ED3;&#x6784;&#xFF1A;
Array &#x3001;Map &#x3001;Set &#x3001;String &#x3001;TypedArray &#x3001;&#x51FD;&#x6570;&#x7684; arguments &#x5BF9;&#x8C61; &#x3001;NodeList &#x5BF9;&#x8C61;

const obj = {};
obj[Symbol.iterator] = arr[Symbol.iterator].bind(arr);
for(let v of obj) {...}

let arr = [&apos;a&apos;, &apos;b&apos;, &apos;c&apos;];
for (let pair of arr.entries()) {...}
entries() //&#x7528;&#x6765;&#x904D;&#x5386;[&#x952E;&#x540D;, &#x952E;&#x503C;]&#x7EC4;&#x6210;&#x7684;&#x6570;&#x7EC4;&#x3002;
keys() //&#x7528;&#x6765;&#x904D;&#x5386;&#x6240;&#x6709;&#x7684;&#x952E;&#x540D;&#x3002;
values()// &#x7528;&#x6765;&#x904D;&#x5386;&#x6240;&#x6709;&#x7684;&#x952E;&#x503C;&#x3002;
</code></pre>
<h2 id="yield-&#x8868;&#x8FBE;&#x5F0F;--&#x3001;-yield-&#x8868;&#x8FBE;&#x5F0F;"><a name="yield-&#x8868;&#x8FBE;&#x5F0F;--&#x3001;-yield-&#x8868;&#x8FBE;&#x5F0F;" class="anchor-navigation-ex-anchor" href="#yield-&#x8868;&#x8FBE;&#x5F0F;--&#x3001;-yield-&#x8868;&#x8FBE;&#x5F0F;"><i class="fa fa-link" aria-hidden="true"></i></a>1.19. yield &#x8868;&#x8FBE;&#x5F0F;  &#x3001; yield* &#x8868;&#x8FBE;&#x5F0F;</h2>
<p>yield &#x5173;&#x952E;&#x5B57;&#x7528;&#x6765;&#x6682;&#x505C;&#x548C;&#x7EE7;&#x7EED;&#x6267;&#x884C;&#x4E00;&#x4E2A;&#x751F;&#x6210;&#x5668;&#x51FD;&#x6570;&#x3002;
&#x5E38;&#x4E0E; Generator&#x751F;&#x6210;&#x51FD;&#x6570; &#x642D;&#x914D;&#x4F7F;&#x7528;&#x3002;</p>
<pre><code class="lang-xml">&#x5F53;&#x5916;&#x90E8;&#x8C03;&#x7528;&#x751F;&#x6210;&#x5668;&#x7684; next() &#x65B9;&#x6CD5;&#x65F6;&#xFF0C;yield &#x5173;&#x952E;&#x5B57;&#x53F3;&#x4FA7;&#x7684;&#x8868;&#x8FBE;&#x5F0F;&#x624D;&#x4F1A;&#x6267;&#x884C;&#x3002;
&#x6267;&#x884C;&#x540E;&#x8FD4;&#x56DE;&#x4E00;&#x4E2A;&#x5BF9;&#x8C61;&#x3002;&#x8BE5;&#x5BF9;&#x8C61;&#x5305;&#x542B;value &#x548C; done&#x4E24;&#x4E2A;&#x5C5E;&#x6027;&#x3002;

var result = yield expression
&#x53D8;&#x91CF; result &#x7684;&#x503C;&#x5C06;&#x5728;&#x4E0B;&#x4E00;&#x6B21;&#x8C03;&#x7528; next() &#x65B9;&#x6CD5;&#x65F6;&#x624D;&#x80FD;&#x62FF;&#x5230;&#xFF0C;&#x5E76;&#x4E14;&#x7B49;&#x4E8E;&#x8C03;&#x7528;&#x65F6; next() &#x65B9;&#x6CD5;&#x7684;&#x63A5;&#x6536;&#x7684;&#x53C2;&#x6570;&#x3002;
&#x4E5F;&#x5C31;&#x662F;&#x8BF4;next()&#x4E2D;&#x8F93;&#x5165;&#x591A;&#x5C11; &#xFF0C;result&#x5C31;&#x662F;&#x591A;&#x5C11; &#x3002; &#x5E76;&#x4E0D;&#x662F; &#x8C03;&#x7528; yield&#x7684;&#x8FD4;&#x56DE;&#x503C; &#x3002;

yield* &#x8868;&#x8FBE;&#x5F0F; &#x7528;&#x6765;&#x5728;&#x4E00;&#x4E2A; Generator &#x51FD;&#x6570;&#x91CC;&#x9762;&#x6267;&#x884C;&#x53E6;&#x4E00;&#x4E2A; Generator &#x51FD;&#x6570;&#x3002;
</code></pre>
<h2 id="generator-&#x751F;&#x6210;&#x51FD;&#x6570;"><a name="generator-&#x751F;&#x6210;&#x51FD;&#x6570;" class="anchor-navigation-ex-anchor" href="#generator-&#x751F;&#x6210;&#x51FD;&#x6570;"><i class="fa fa-link" aria-hidden="true"></i></a>1.20. Generator &#x751F;&#x6210;&#x51FD;&#x6570;</h2>
<p>Generator &#x51FD;&#x6570;&#x662F; ES6 &#x63D0;&#x4F9B;&#x7684;&#x4E00;&#x79CD;&#x5F02;&#x6B65;&#x7F16;&#x7A0B;&#x89E3;&#x51B3;&#x65B9;&#x6848;&#x3002;</p>
<pre><code class="lang-xml">Generator &#x51FD;&#x6570;&#x662F;&#x4E00;&#x4E2A;&#x666E;&#x901A;&#x51FD;&#x6570;&#xFF0C;&#x4F46;&#x662F;&#x6709;&#x4E24;&#x4E2A;&#x7279;&#x5F81;&#x3002;
1&#x3001;function&#x5173;&#x952E;&#x5B57;&#x4E0E;&#x51FD;&#x6570;&#x540D;&#x4E4B;&#x95F4;&#x6709;&#x4E00;&#x4E2A;&#x661F;&#x53F7;&#xFF1B;
2&#x3001;&#x51FD;&#x6570;&#x4F53;&#x5185;&#x90E8;&#x4F7F;&#x7528;yield&#x8868;&#x8FBE;&#x5F0F;

function* helloWorldGenerator() {
  yield &apos;hello&apos;;
  yield &apos;world&apos;;
  return &apos;ending&apos;;
}
&#x5B9A;&#x4E49;&#x4E86;&#x4E00;&#x4E2A; Generator &#x51FD;&#x6570;helloWorldGenerator&#xFF0C;
&#x5B83;&#x5185;&#x90E8;&#x6709;&#x4E24;&#x4E2A;yield&#x8868;&#x8FBE;&#x5F0F;&#xFF08;hello&#x548C;world&#xFF09;&#xFF0C;&#x5373;&#x8BE5;&#x51FD;&#x6570;&#x6709;&#x4E09;&#x4E2A;&#x72B6;&#x6001;&#xFF1A;hello&#xFF0C;world &#x548C; return &#x8BED;&#x53E5;&#xFF08;&#x7ED3;&#x675F;&#x6267;&#x884C;&#xFF09;&#x3002;

var hw = helloWorldGenerator();
&#x8C03;&#x7528; Generator &#x51FD;&#x6570;&#x540E;&#xFF0C;&#x8BE5;&#x51FD;&#x6570;&#x5E76;&#x4E0D;&#x4F1A;&#x6267;&#x884C; &#x3002;&#x5FC5;&#x987B;&#x8C03;&#x7528;&#x5BF9;&#x8C61;&#x7684;next&#x65B9;&#x6CD5;&#xFF0C;&#x4F7F;&#x5F97;&#x6307;&#x9488;&#x79FB;&#x5411;&#x4E0B;&#x4E00;&#x4E2A;&#x72B6;&#x6001;&#x3002;
Generator &#x51FD;&#x6570;&#x662F;&#x5206;&#x6BB5;&#x6267;&#x884C;&#x7684;&#xFF0C;yield&#x8868;&#x8FBE;&#x5F0F;&#x662F;&#x6682;&#x505C;&#x6267;&#x884C;&#x7684;&#x6807;&#x8BB0;&#xFF0C;&#x800C;next&#x65B9;&#x6CD5;&#x53EF;&#x4EE5;&#x6062;&#x590D;&#x6267;&#x884C;&#x3002;
</code></pre>
<h2 id="async-&#x51FD;&#x6570;"><a name="async-&#x51FD;&#x6570;" class="anchor-navigation-ex-anchor" href="#async-&#x51FD;&#x6570;"><i class="fa fa-link" aria-hidden="true"></i></a>1.21. async &#x51FD;&#x6570;</h2>
<p>&#x5B83;&#x662F; Generator &#x51FD;&#x6570;&#x7684;&#x8BED;&#x6CD5;&#x7CD6;&#x3002;
ES2017(ES8) &#x6807;&#x51C6;&#x5F15;&#x5165;&#x4E86; async &#x51FD;&#x6570;&#xFF0C;&#x4F7F;&#x5F97;&#x5F02;&#x6B65;&#x64CD;&#x4F5C;&#x53D8;&#x5F97;&#x66F4;&#x52A0;&#x65B9;&#x4FBF;&#x3002;</p>
<pre><code class="lang-xml">async&#x51FD;&#x6570;&#x5C31;&#x662F;&#x5C06; Generator &#x51FD;&#x6570;&#x7684;&#x661F;&#x53F7;&#xFF08;*&#xFF09;&#x66FF;&#x6362;&#x6210;async&#xFF0C;&#x5C06;yield&#x66FF;&#x6362;&#x6210;await&#xFF0C;&#x4EC5;&#x6B64;&#x800C;&#x5DF2;&#x3002;
</code></pre>
<h2 id="class-&#x7C7B;"><a name="class-&#x7C7B;" class="anchor-navigation-ex-anchor" href="#class-&#x7C7B;"><i class="fa fa-link" aria-hidden="true"></i></a>1.22. class &#x7C7B;</h2>
<p>ES6 &#x63D0;&#x4F9B;&#x4E86;&#x66F4;&#x63A5;&#x8FD1;&#x4F20;&#x7EDF;&#x8BED;&#x8A00;&#x7684;&#x5199;&#x6CD5;&#xFF0C;&#x5F15;&#x5165;&#x4E86; class &#x8FD9;&#x4E2A;&#x6982;&#x5FF5; &#x3002;&#x901A;&#x8FC7;&#x5173;&#x952E;&#x5B57;class&#x5B9A;&#x4E49;&#x7C7B;&#x3002;</p>
<pre><code class="lang-xml">//&#x6784;&#x9020;&#x65B9;&#x6CD5;
&#x4E00;&#x4E2A;&#x7C7B;&#x5FC5;&#x987B;&#x6709;constructor&#x65B9;&#x6CD5;&#xFF0C;&#x5982;&#x679C;&#x6CA1;&#x6709;&#x663E;&#x5F0F;&#x5B9A;&#x4E49;&#xFF0C;&#x4F1A;&#x9ED8;&#x8BA4;&#x6DFB;&#x52A0;&#x4E00;&#x4E2A;&#x7A7A;&#x7684;&#x6784;&#x9020;&#x65B9;&#x6CD5;&#x3002;
</code></pre>
<h3 id="class-&#x8868;&#x8FBE;&#x5F0F;"><a name="class-&#x8868;&#x8FBE;&#x5F0F;" class="anchor-navigation-ex-anchor" href="#class-&#x8868;&#x8FBE;&#x5F0F;"><i class="fa fa-link" aria-hidden="true"></i></a>1.22.1. Class &#x8868;&#x8FBE;&#x5F0F;</h3>
<p>&#x7C7B;&#x4E5F;&#x53EF;&#x4EE5;&#x4F7F;&#x7528;&#x8868;&#x8FBE;&#x5F0F;&#x7684;&#x5F62;&#x5F0F;&#x5B9A;&#x4E49;   </p>
<pre><code class="lang-xml">// &#x8FD9;&#x4E2A;&#x7C7B;&#x7684;&#x540D;&#x5B57;&#x662F;MyClass ,TempName&#x53EA;&#x5728; Class &#x7684;&#x5185;&#x90E8;&#x4EE3;&#x7801;&#x53EF;&#x7528;&#xFF0C;&#x6307;&#x4EE3;&#x5F53;&#x524D;&#x7C7B;&#x3002;
const MyClass = class TempName {
  getClassName() {
    return tempName.name;
  }
};

// &#x751F;&#x6210;&#x53EF;&#x4EE5;&#x7ACB;&#x5373;&#x6267;&#x884C;&#x7684;&#x7C7B;&#x5B9E;&#x4F8B;
let person = new class {
  constructor(name) {
    this.name = name;
  }
  sayName() {
    console.log(this .name);
  }
}(&apos;tomcat&apos;);
person.sayName(); // &quot;tomcat&quot;
</code></pre>
<h3 id="class&#x7684;&#x7EE7;&#x627F;"><a name="class&#x7684;&#x7EE7;&#x627F;" class="anchor-navigation-ex-anchor" href="#class&#x7684;&#x7EE7;&#x627F;"><i class="fa fa-link" aria-hidden="true"></i></a>1.22.2. class&#x7684;&#x7EE7;&#x627F;</h3>
<p>ES5 &#x901A;&#x8FC7;&#x4FEE;&#x6539;&#x539F;&#x578B;&#x94FE;&#x5B9E;&#x73B0;&#x7EE7;&#x627F;&#x3002;
ES6 &#x53EF;&#x4EE5;&#x901A;&#x8FC7;extends&#x5173;&#x952E;&#x5B57;&#x5B9E;&#x73B0;&#x7EE7;&#x627F;,&#x66F4;&#x65B9;&#x4FBF;&#x3002;</p>
<pre><code class="lang-xml">Object.getPrototypeOf()
&#x4ECE;&#x5B50;&#x7C7B;&#x4E0A;&#x83B7;&#x53D6;&#x7236;&#x7C7B;&#x3002;
</code></pre>
<h3 id="&#x7C7B;&#x7684;super&#x5173;&#x952E;&#x5B57;"><a name="&#x7C7B;&#x7684;super&#x5173;&#x952E;&#x5B57;" class="anchor-navigation-ex-anchor" href="#&#x7C7B;&#x7684;super&#x5173;&#x952E;&#x5B57;"><i class="fa fa-link" aria-hidden="true"></i></a>1.22.3. &#x7C7B;&#x7684;super&#x5173;&#x952E;&#x5B57;</h3>
<p>super&#x8FD9;&#x4E2A;&#x5173;&#x952E;&#x5B57;&#xFF0C;&#x65E2;&#x53EF;&#x4EE5;&#x5F53;&#x4F5C;&#x51FD;&#x6570;&#x4F7F;&#x7528;&#xFF0C;&#x4E5F;&#x53EF;&#x4EE5;&#x5F53;&#x4F5C;&#x5BF9;&#x8C61;&#x4F7F;&#x7528;&#x3002;</p>
<pre><code class="lang-xml">ES6 &#x8981;&#x6C42;&#xFF0C;&#x5B50;&#x7C7B;&#x7684;&#x6784;&#x9020;&#x51FD;&#x6570;&#x5FC5;&#x987B;&#x6267;&#x884C;&#x4E00;&#x6B21;super&#x51FD;&#x6570;&#x3002;
class B extends A {
  constructor() {
    // &#x4EE3;&#x8868;&#x7236;&#x7C7B;&#x7684;&#x6784;&#x9020;&#x51FD;&#x6570;
    super();
  }
}

class B extends A {
  constructor() {
    super();
    // super &#x5728;&#x666E;&#x901A;&#x65B9;&#x6CD5;&#x4E2D;&#xFF0C;super &#x6307;&#x5411;&#x7236;&#x7C7B;&#x7684;&#x539F;&#x578B;&#x5BF9;&#x8C61;&#xFF1B;&#x5728;&#x9759;&#x6001;&#x65B9;&#x6CD5;&#x4E2D;&#xFF0C;&#x6307;&#x5411;&#x7236;&#x7C7B;&#x3002;
    console.log(super.p());
  }
}
</code></pre>
<h3 id="mixin-&#x7EC4;&#x5408;&#x6A21;&#x5F0F;-&#x5B9E;&#x73B0;-&#x591A;&#x7EE7;&#x627F;"><a name="mixin-&#x7EC4;&#x5408;&#x6A21;&#x5F0F;-&#x5B9E;&#x73B0;-&#x591A;&#x7EE7;&#x627F;" class="anchor-navigation-ex-anchor" href="#mixin-&#x7EC4;&#x5408;&#x6A21;&#x5F0F;-&#x5B9E;&#x73B0;-&#x591A;&#x7EE7;&#x627F;"><i class="fa fa-link" aria-hidden="true"></i></a>1.22.4. Mixin &#x7EC4;&#x5408;&#x6A21;&#x5F0F; &#x5B9E;&#x73B0; &#x591A;&#x7EE7;&#x627F;</h3>
<p>js&#x662F;&#x4E00;&#x79CD;&#x53EA;&#x652F;&#x6301;&#x5355;&#x7EE7;&#x627F;&#x7684;&#x8BED;&#x8A00;&#xFF0C;&#x5982;&#x679C;&#x60F3;&#x5B9E;&#x73B0;&#x591A;&#x7EE7;&#x627F;&#xFF0C;&#x90A3;&#x5C31;&#x7B80;&#x5355;&#x66B4;&#x529B;&#x7684;&#x628A;&#x9700;&#x8981;&#x7EE7;&#x627F;&#x7684;&#x7236;&#x7C7B;&#x7684;&#x6240;&#x6709;&#x5C5E;&#x6027;&#x90FD;&#x62F7;&#x8D1D;&#x5230;&#x5B50;&#x7C7B;&#x4E0A;&#x3002;</p>
<pre><code class="lang-xml">function mixin(...objs){
    return objs.reduce((dest, src) =&gt; {
        for (var key in src) {
            dest[key] = src[key]
        }
        return dest;    
    });
}
var dest = mixin({...}, src1, src2, src3);
</code></pre>
<h2 id="&#x4FEE;&#x9970;&#x5668;-&#x3001;-decorator"><a name="&#x4FEE;&#x9970;&#x5668;-&#x3001;-decorator" class="anchor-navigation-ex-anchor" href="#&#x4FEE;&#x9970;&#x5668;-&#x3001;-decorator"><i class="fa fa-link" aria-hidden="true"></i></a>1.23. &#x4FEE;&#x9970;&#x5668; &#x3001; Decorator</h2>
<p>&#x88C5;&#x9970;&#x5668;&#x662F;&#x5BF9;&#x7C7B;&#x3001;&#x51FD;&#x6570;&#x3001;&#x5C5E;&#x6027;&#x4E4B;&#x7C7B;&#x7684;&#x4E00;&#x79CD;&#x88C5;&#x9970;&#xFF0C;&#x53EF;&#x4EE5;&#x9488;&#x5BF9;&#x5176;&#x6DFB;&#x52A0;&#x4E00;&#x4E9B;&#x989D;&#x5916;&#x7684;&#x884C;&#x4E3A;&#x3002;&#x901A;&#x4FD7;&#x7684;&#x7406;&#x89E3;&#x53EF;&#x4EE5;&#x8BA4;&#x4E3A;&#x5C31;&#x662F;&#x5728;&#x539F;&#x6709;&#x4EE3;&#x7801;&#x5916;&#x5C42;&#x5305;&#x88C5;&#x4E86;&#x4E00;&#x5C42;&#x5904;&#x7406;&#x903B;&#x8F91;&#x3002;
&#x76EE;&#x524D;&#x8FD8;&#x6CA1;&#x6709;&#x76F4;&#x63A5;&#x652F;&#x6301;&#x8BE5;&#x8BED;&#x6CD5;&#x7684;&#x73AF;&#x5883;&#xFF0C;&#x9700;&#x8981;&#x501F;&#x52A9;&#x4E00;&#x4E9B;&#x7B2C;&#x4E09;&#x65B9;&#x7684;&#x5E93;&#xFF08;&#x4F1A;&#x81EA;&#x5B9A;&#x8FDB;&#x884C;&#x76F8;&#x5E94;&#x7684;&#x8BED;&#x6CD5;&#x8F6C;&#x6362;&#xFF09;&#x3002;</p>
<h2 id="&#x6A21;&#x5757;&#x5316;-&#x3001;module"><a name="&#x6A21;&#x5757;&#x5316;-&#x3001;module" class="anchor-navigation-ex-anchor" href="#&#x6A21;&#x5757;&#x5316;-&#x3001;module"><i class="fa fa-link" aria-hidden="true"></i></a>1.24. &#x6A21;&#x5757;&#x5316; &#x3001;Module</h2>
<p>&#x5728; ES6 &#x4E4B;&#x524D;&#xFF0C;&#x793E;&#x533A;&#x5236;&#x5B9A;&#x4E86;&#x4E00;&#x4E9B;&#x6A21;&#x5757;&#x52A0;&#x8F7D;&#x65B9;&#x6848;&#xFF0C;&#x6700;&#x4E3B;&#x8981;&#x7684;&#x6709; CommonJS &#x548C; AMD &#x4E24;&#x79CD;&#x3002;&#x524D;&#x8005;&#x7528;&#x4E8E;&#x670D;&#x52A1;&#x5668;&#xFF0C;&#x540E;&#x8005;&#x7528;&#x4E8E;&#x6D4F;&#x89C8;&#x5668;&#x3002;</p>
<p>CommonJS &#x548C; AMD &#x6A21;&#x5757;&#xFF0C;&#x90FD;&#x53EA;&#x80FD;&#x5728;&#x8FD0;&#x884C;&#x65F6;&#x786E;&#x5B9A;&#x52A0;&#x8F7D;&#x54EA;&#x4E9B;&#x4E1C;&#x897F;&#x3002;ES6 &#x53EF;&#x4EE5;&#x5728;&#x7F16;&#x8BD1;&#x65F6;&#x5C31;&#x5B8C;&#x6210;&#x6A21;&#x5757;&#x52A0;&#x8F7D;&#xFF0C;&#x6548;&#x7387;&#x8981;&#x6BD4; CommonJS &#x6A21;&#x5757;&#x7684;&#x52A0;&#x8F7D;&#x65B9;&#x5F0F;&#x9AD8;&#x3002;</p>
<h4 id="export-&#x3001;-export-default-&#x3001;import"><a name="export-&#x3001;-export-default-&#x3001;import" class="anchor-navigation-ex-anchor" href="#export-&#x3001;-export-default-&#x3001;import"><i class="fa fa-link" aria-hidden="true"></i></a>export &#x3001; export default &#x3001;import</h4>
<pre><code class="lang-xml">&#x4E00;&#x4E2A;&#x6A21;&#x5757;&#x5C31;&#x662F;&#x4E00;&#x4E2A;&#x72EC;&#x7ACB;&#x7684;&#x6587;&#x4EF6;&#x3002;&#x8BE5;&#x6587;&#x4EF6;&#x5185;&#x90E8;&#x7684;&#x6240;&#x6709;&#x53D8;&#x91CF;&#xFF0C;&#x5916;&#x90E8;&#x65E0;&#x6CD5;&#x83B7;&#x53D6;&#x3002;
&#x5982;&#x679C;&#x5E0C;&#x671B;&#x5916;&#x90E8;&#x80FD;&#x591F;&#x8BFB;&#x53D6;&#x6A21;&#x5757;&#x5185;&#x90E8;&#x7684;&#x67D0;&#x4E2A;&#x53D8;&#x91CF;&#xFF0C;&#x5C31;&#x5FC5;&#x987B;&#x4F7F;&#x7528;export&#x5173;&#x952E;&#x5B57;&#x8F93;&#x51FA;&#x8BE5;&#x53D8;&#x91CF;&#x3002;

// &#x5BF9;&#x5916;&#x8F93;&#x51FA;&#x4E00;&#x4E2A;&#x53D8;&#x91CF;
export var firstName = &apos;tomcat&apos;;
// &#x8F93;&#x51FA;&#x4E00;&#x7EC4;&#x53D8;&#x91CF;
export {firstName, lastName, year};

// &#x8F93;&#x51FA;&#x51FD;&#x6570;
export function multiply(x, y) {...};

// &#x5C06;&#x51FD;&#x6570;&#x91CD;&#x547D;&#x540D;&#x540E;&#x518D;&#x8F93;&#x51FA;
function f1() { ... }
export {
  f1 as streamV1,
};

// &#x5BFC;&#x5165;&#x4E00;&#x4E2A;&#x53D8;&#x91CF;
import {firstName} from &apos;./profile.js&apos;;

// &#x5BFC;&#x5165;&#x4E00;&#x7EC4;&#x53D8;&#x91CF;
import {firstName, lastName, year} from &apos;./profile.js&apos;;

// &#x5C06;&#x5BFC;&#x5165;&#x7684;&#x53D8;&#x91CF;&#x91CD;&#x547D;&#x540D;
import { lastName as surname } from &apos;./profile.js&apos;;

// &#x5BFC;&#x5165;&#x6574;&#x4E2A;&#x6A21;&#x5757; ,&#x53EF;&#x4EE5;&#x4F7F;&#x7528;&#x8FD9;&#x4E2A;&#x6A21;&#x5757;&#x4E2D;&#x7684;&#x6240;&#x6709;&#x503C;
import * as profile from &apos;./profile&apos;;

// customNmae&#x8FD9;&#x4E2A;&#x540D;&#x5B57;&#x53EF;&#x4EE5;&#x968F;&#x610F;&#x5199;&#xFF0C;&#x5E76;&#x4E0D;&#x8981;&#x6C42;&#x662F;&#x51FD;&#x6570;&#x7684;&#x540D;&#x5B57;
export default function foo() {...}
export default function () { ...}
import customName from &apos;./export-default&apos;;

export &#x3001; export default&#x5747;&#x53EF;&#x7528;&#x4E8E;&#x5BFC;&#x51FA; &#x5E38;&#x91CF;&#x3001;&#x53D8;&#x91CF;&#x3001;&#x51FD;&#x6570;&#x3001;&#x7C7B;&#x6587;&#x4EF6;
&#x5728;&#x4E00;&#x4E2A;&#x6587;&#x4EF6;&#x6216;&#x6A21;&#x5757;&#x4E2D;&#xFF0C;export&#x3001;import&#x53EF;&#x4EE5;&#x6709;&#x591A;&#x4E2A;&#xFF0C;export default&#x4EC5;&#x6709;&#x4E00;&#x4E2A;
&#x901A;&#x8FC7;export&#x65B9;&#x5F0F;&#x5BFC;&#x51FA;&#xFF0C;&#x5728;&#x5BFC;&#x5165;&#x65F6;&#x8981;&#x52A0;{ }&#xFF0C;export default&#x5219;&#x4E0D;&#x9700;&#x8981;
export&#x80FD;&#x76F4;&#x63A5;&#x5BFC;&#x51FA;&#x53D8;&#x91CF;&#x8868;&#x8FBE;&#x5F0F;&#xFF0C;export default&#x4E0D;&#x884C;&#x3002;
</code></pre>
<h2 id="&#x4E8C;&#x8FDB;&#x5236;&#x6570;&#x7EC4;"><a name="&#x4E8C;&#x8FDB;&#x5236;&#x6570;&#x7EC4;" class="anchor-navigation-ex-anchor" href="#&#x4E8C;&#x8FDB;&#x5236;&#x6570;&#x7EC4;"><i class="fa fa-link" aria-hidden="true"></i></a>1.25. &#x4E8C;&#x8FDB;&#x5236;&#x6570;&#x7EC4;</h2>
<p>&#x4EE5;&#x6570;&#x7EC4;&#x7684;&#x8BED;&#x6CD5;&#x5904;&#x7406;&#x4E8C;&#x8FDB;&#x5236;&#x6570;&#x636E;&#x3002;&#x4E8C;&#x8FDB;&#x5236;&#x6570;&#x7EC4;&#x5E76;&#x4E0D;&#x662F;&#x771F;&#x6B63;&#x7684;&#x6570;&#x7EC4;&#xFF0C;&#x800C;&#x662F;&#x7C7B;&#x4F3C;&#x6570;&#x7EC4;&#x7684;&#x5BF9;&#x8C61;&#x3002;</p>
<h3 id="&#x4E8C;&#x8FDB;&#x5236;&#x6570;&#x7EC4;---arraybuffer"><a name="&#x4E8C;&#x8FDB;&#x5236;&#x6570;&#x7EC4;---arraybuffer" class="anchor-navigation-ex-anchor" href="#&#x4E8C;&#x8FDB;&#x5236;&#x6570;&#x7EC4;---arraybuffer"><i class="fa fa-link" aria-hidden="true"></i></a>1.25.1. &#x4E8C;&#x8FDB;&#x5236;&#x6570;&#x7EC4; - ArrayBuffer</h3>
<p>&#x4EE3;&#x8868;&#x539F;&#x59CB;&#x7684;&#x4E8C;&#x8FDB;&#x5236;&#x6570;&#x636E; &#xFF0C;ArrayBuffer&#x5BF9;&#x8C61;&#x4EE3;&#x8868;&#x50A8;&#x5B58;&#x4E8C;&#x8FDB;&#x5236;&#x6570;&#x636E;&#x7684;&#x4E00;&#x6BB5;&#x5185;&#x5B58;&#xFF0C;&#x5B83;&#x4E0D;&#x80FD;&#x76F4;&#x63A5;&#x8BFB;&#x5199;&#xFF0C;&#x53EA;&#x80FD;&#x901A;&#x8FC7; TypedArray &#x548C;DataView &#x6765;&#x8BFB;&#x5199;&#x3002;</p>
<table>
<thead>
<tr>
<th>&#x5C5E;&#x6027;&#x6216;&#x65B9;&#x6CD5;</th>
<th>&#x8BF4;&#x660E;</th>
</tr>
</thead>
<tbody>
<tr>
<td>byteLength</td>
<td>&#x8FD4;&#x56DE;&#x6240;&#x5206;&#x914D;&#x7684;&#x5185;&#x5B58;&#x533A;&#x57DF;&#x7684;&#x5B57;&#x8282;&#x957F;&#x5EA6;</td>
</tr>
<tr>
<td>slice()</td>
<td>&#x5C06;&#x5185;&#x5B58;&#x533A;&#x57DF;&#x7684;&#x4E00;&#x90E8;&#x5206;&#xFF0C;&#x62F7;&#x8D1D;&#x751F;&#x6210;&#x4E00;&#x4E2A;&#x65B0;&#x7684;ArrayBuffer&#x5BF9;&#x8C61;</td>
</tr>
<tr>
<td>ArrayBuffer.isView(buffer)</td>
<td>&#x8868;&#x793A;&#x53C2;&#x6570;&#x662F;&#x5426;&#x4E3A;ArrayBuffer&#x7684;&#x89C6;&#x56FE;&#x5B9E;&#x4F8B;&#x3002;</td>
</tr>
</tbody>
</table>
<h3 id="&#x4E8C;&#x8FDB;&#x5236;&#x6570;&#x7EC4;---typedarray"><a name="&#x4E8C;&#x8FDB;&#x5236;&#x6570;&#x7EC4;---typedarray" class="anchor-navigation-ex-anchor" href="#&#x4E8C;&#x8FDB;&#x5236;&#x6570;&#x7EC4;---typedarray"><i class="fa fa-link" aria-hidden="true"></i></a>1.25.2. &#x4E8C;&#x8FDB;&#x5236;&#x6570;&#x7EC4; - TypedArray</h3>
<p>&#x7528;&#x6765;&#x8BFB;&#x5199;&#x7B80;&#x5355;&#x7C7B;&#x578B;&#x7684;&#x4E8C;&#x8FDB;&#x5236;&#x6570;&#x636E;&#x3002; &#x6570;&#x7EC4;&#x6210;&#x5458;&#x90FD;&#x662F;&#x540C;&#x4E00;&#x4E2A;&#x6570;&#x636E;&#x7C7B;&#x578B;&#x3002;</p>
<table>
<thead>
<tr>
<th>TypedArray&#x7684;&#x7C7B;&#x578B;</th>
<th>&#x8BF4;&#x660E;</th>
</tr>
</thead>
<tbody>
<tr>
<td>Int8Array</td>
<td>8 &#x4F4D;&#x6709;&#x7B26;&#x53F7;&#x6574;&#x6570;&#xFF0C;&#x957F;&#x5EA6; 1 &#x4E2A;&#x5B57;&#x8282;&#x3002;</td>
</tr>
<tr>
<td>Uint8Array</td>
<td>8 &#x4F4D;&#x65E0;&#x7B26;&#x53F7;&#x6574;&#x6570;&#xFF0C;&#x957F;&#x5EA6; 1 &#x4E2A;&#x5B57;&#x8282;&#x3002;</td>
</tr>
<tr>
<td>Uint8ClampedArray</td>
<td>8 &#x4F4D;&#x65E0;&#x7B26;&#x53F7;&#x6574;&#x6570;&#xFF0C;&#x957F;&#x5EA6; 1 &#x4E2A;&#x5B57;&#x8282;&#xFF0C;&#x6EA2;&#x51FA;&#x5904;&#x7406;&#x4E0D;&#x540C;&#x3002;</td>
</tr>
<tr>
<td>Int16Array</td>
<td>16 &#x4F4D;&#x6709;&#x7B26;&#x53F7;&#x6574;&#x6570;&#xFF0C;&#x957F;&#x5EA6; 2 &#x4E2A;&#x5B57;&#x8282;&#x3002;</td>
</tr>
<tr>
<td>Uint16Array</td>
<td>16 &#x4F4D;&#x65E0;&#x7B26;&#x53F7;&#x6574;&#x6570;&#xFF0C;&#x957F;&#x5EA6; 2 &#x4E2A;&#x5B57;&#x8282;&#x3002;</td>
</tr>
<tr>
<td>Int32Array</td>
<td>32 &#x4F4D;&#x6709;&#x7B26;&#x53F7;&#x6574;&#x6570;&#xFF0C;&#x957F;&#x5EA6; 4 &#x4E2A;&#x5B57;&#x8282;&#x3002;</td>
</tr>
<tr>
<td>Uint32Array</td>
<td>32 &#x4F4D;&#x65E0;&#x7B26;&#x53F7;&#x6574;&#x6570;&#xFF0C;&#x957F;&#x5EA6; 4 &#x4E2A;&#x5B57;&#x8282;&#x3002;</td>
</tr>
<tr>
<td>Float32Array</td>
<td>32 &#x4F4D;&#x6D6E;&#x70B9;&#x6570;&#xFF0C;&#x957F;&#x5EA6; 4 &#x4E2A;&#x5B57;&#x8282;&#x3002;</td>
</tr>
<tr>
<td>Float64Array</td>
<td>64 &#x4F4D;&#x6D6E;&#x70B9;&#x6570;&#xFF0C;&#x957F;&#x5EA6; 8 &#x4E2A;&#x5B57;&#x8282;&#x3002;</td>
</tr>
</tbody>
</table>
<table>
<thead>
<tr>
<th>TypedArray &#x7684;&#x5C5E;&#x6027;&#x6216;&#x65B9;&#x6CD5;</th>
<th>&#x8BF4;&#x660E;</th>
</tr>
</thead>
<tbody>
<tr>
<td>TypedArray.prototype.copyWithin(target, start[, end = this.length])</td>
<td></td>
</tr>
<tr>
<td>TypedArray.prototype.entries()</td>
<td></td>
</tr>
<tr>
<td>TypedArray.prototype.every(callbackfn, thisArg?)</td>
<td></td>
</tr>
<tr>
<td>TypedArray.prototype.fill(value, start=0, end=this.length)</td>
<td></td>
</tr>
<tr>
<td>TypedArray.prototype.filter(callbackfn, thisArg?)</td>
<td></td>
</tr>
<tr>
<td>TypedArray.prototype.find(predicate, thisArg?)</td>
<td></td>
</tr>
<tr>
<td>TypedArray.prototype.findIndex(predicate, thisArg?)</td>
<td></td>
</tr>
<tr>
<td>TypedArray.prototype.forEach(callbackfn, thisArg?)</td>
<td></td>
</tr>
<tr>
<td>TypedArray.prototype.indexOf(searchElement, fromIndex=0)</td>
<td></td>
</tr>
<tr>
<td>TypedArray.prototype.join(separator)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>TypedArray.prototype.keys()</td>
<td></td>
</tr>
<tr>
<td>TypedArray.prototype.lastIndexOf(searchElement, fromIndex?)</td>
<td></td>
</tr>
<tr>
<td>TypedArray.prototype.map(callbackfn, thisArg?)</td>
<td></td>
</tr>
<tr>
<td>TypedArray.prototype.reduce(callbackfn, initialValue?)</td>
<td></td>
</tr>
<tr>
<td>TypedArray.prototype.reduceRight(callbackfn, initialValue?)</td>
<td></td>
</tr>
<tr>
<td>TypedArray.prototype.reverse()</td>
<td></td>
</tr>
<tr>
<td>TypedArray.prototype.slice(start=0, end=this.length)</td>
<td></td>
</tr>
<tr>
<td>TypedArray.prototype.some(callbackfn, thisArg?)</td>
<td></td>
</tr>
<tr>
<td>TypedArray.prototype.sort(comparefn)</td>
<td></td>
</tr>
<tr>
<td>TypedArray.prototype.toLocaleString(reserved1?, reserved2?)</td>
<td></td>
</tr>
<tr>
<td>TypedArray.prototype.toString()</td>
<td></td>
</tr>
<tr>
<td>TypedArray.prototype.values()</td>
<td></td>
</tr>
<tr>
<td>BYTES_PER_ELEMENT</td>
<td>&#x8868;&#x793A;&#x8FD9;&#x79CD;&#x6570;&#x636E;&#x7C7B;&#x578B;&#x5360;&#x636E;&#x7684;&#x5B57;&#x8282;&#x6570;&#x3002;</td>
</tr>
<tr>
<td>Float32Array.of()</td>
<td>TypedArray &#x6570;&#x7EC4;&#x7684;&#x6240;&#x6709;&#x6784;&#x9020;&#x51FD;&#x6570;&#xFF0C;&#x90FD;&#x6709;&#x4E00;&#x4E2A;&#x9759;&#x6001;&#x65B9;&#x6CD5;of&#xFF0C;&#x7528;&#x4E8E;&#x5C06;&#x53C2;&#x6570;&#x8F6C;&#x4E3A;&#x4E00;&#x4E2A; TypedArray &#x5B9E;&#x4F8B;&#x3002;</td>
</tr>
<tr>
<td>Uint16Array.from([0, 1, 2])</td>
<td>&#x63A5;&#x53D7;&#x4E00;&#x4E2A;&#x53EF;&#x904D;&#x5386;&#x7684;&#x6570;&#x636E;&#x7ED3;&#x6784;&#xFF08;&#x6BD4;&#x5982;&#x6570;&#x7EC4;&#xFF09;&#x4F5C;&#x4E3A;&#x53C2;&#x6570;&#xFF0C;&#x8FD4;&#x56DE;&#x4E00;&#x4E2A;&#x57FA;&#x4E8E;&#x8FD9;&#x4E2A;&#x7ED3;&#x6784;&#x7684; TypedArray &#x5B9E;&#x4F8B;&#x3002;</td>
</tr>
</tbody>
</table>
<h3 id="&#x4E8C;&#x8FDB;&#x5236;&#x6570;&#x7EC4;---dataview"><a name="&#x4E8C;&#x8FDB;&#x5236;&#x6570;&#x7EC4;---dataview" class="anchor-navigation-ex-anchor" href="#&#x4E8C;&#x8FDB;&#x5236;&#x6570;&#x7EC4;---dataview"><i class="fa fa-link" aria-hidden="true"></i></a>1.25.3. &#x4E8C;&#x8FDB;&#x5236;&#x6570;&#x7EC4; - DataView</h3>
<p>&#x7528;&#x6765;&#x8BFB;&#x5199;&#x590D;&#x6742;&#x7C7B;&#x578B;&#x7684;&#x4E8C;&#x8FDB;&#x5236;&#x6570;&#x636E; &#x3002;&#x6570;&#x7EC4;&#x6210;&#x5458;&#x53EF;&#x4EE5;&#x662F;&#x4E0D;&#x540C;&#x7684;&#x6570;&#x636E;&#x7C7B;&#x578B;&#x3002;</p>
<pre><code class="lang-xml">const buffer = new ArrayBuffer(24);
const dv = new DataView(buffer);
// &#x4ECE;&#x7B2C;4&#x4E2A;&#x5B57;&#x8282;&#x8BFB;&#x53D6;&#x4E00;&#x4E2A;16&#x4F4D;&#x65E0;&#x7B26;&#x53F7;&#x6574;&#x6570;
const v3 = dv.getUint16(3);
// &#x5C0F;&#x7AEF;&#x5B57;&#x8282;&#x5E8F;
const v1 = dv.getUint16(1, true);
// &#x5927;&#x7AEF;&#x5B57;&#x8282;&#x5E8F;
const v2 = dv.getUint16(3, false);
</code></pre>
<footer class="page-footer"><span class="copyright">&#x65E0;&#x7248;&#x6743; &#x53EF;&#x4EE5;&#x65E0;&#x9650;&#x5236;&#x4F7F;&#x7528;&#xFF01; all right reserved&#xFF0C;powered by Gitbook</span><span class="footer-modification">&#x8BE5;&#x6587;&#x4EF6;&#x66F4;&#x65B0;&#x65F6;&#x95F4;&#xFF1A;
2018-10-31 14:09:59
</span></footer>
                                
                                </section>
                            
    </div>
    <div class="search-results">
        <div class="has-results">
            
            <h1 class="search-results-title"><span class='search-results-count'></span> results matching "<span class='search-query'></span>"</h1>
            <ul class="search-results-list"></ul>
            
        </div>
        <div class="no-results">
            
            <h1 class="search-results-title">No results matching "<span class='search-query'></span>"</h1>
            
        </div>
    </div>
</div>

                        </div>
                    </div>
                
            </div>

            
                
                <a href="CommonJS.html" class="navigation navigation-prev " aria-label="Previous page: CommonJS">
                    <i class="fa fa-angle-left"></i>
                </a>
                
                
                <a href="mockjs.html" class="navigation navigation-next " aria-label="Next page: mockjs">
                    <i class="fa fa-angle-right"></i>
                </a>
                
            
        
    </div>

    <script>
        var gitbook = gitbook || [];
        gitbook.push(function() {
            gitbook.page.hasChanged({"page":{"title":"ES6","level":"1.3.6","depth":2,"next":{"title":"mockjs","level":"1.3.7","depth":2,"path":"chinese/web/mockjs.md","ref":"chinese/web/mockjs.md","articles":[]},"previous":{"title":"CommonJS","level":"1.3.5","depth":2,"path":"chinese/web/CommonJS.md","ref":"chinese/web/CommonJS.md","articles":[]},"dir":"ltr"},"config":{"plugins":["-search","search-plus","todo","anchor-navigation-ex","copy-code-button","fontsettings","tbfed-pagefooter","donate","local-video","splitter","favicon","theme-comscore","local-video"],"styles":{"website":"styles/website.css"},"pluginsConfig":{"tbfed-pagefooter":{"copyright":"无版权 可以无限制使用！","modify_label":"该文件更新时间：","modify_format":"YYYY-MM-DD HH:mm:ss"},"todo":{},"splitter":{},"lunr":{"maxIndexSize":1000000,"ignoreSpecialCharacters":false},"donate":{"alipay":"http://oyru0ayig.bkt.clouddn.com/201803011956_osChina_支付宝收款码.png","alipayText":"支付宝打赏","button":"打赏","title":"","wechat":"http://oyru0ayig.bkt.clouddn.com/201803011956_osChina_微信收款码.png","wechatText":"微信打赏"},"fontsettings":{"family":"sans","size":2,"theme":"sepia"},"highlight":{},"anchor-navigation-ex":{"associatedWithSummary":true,"float":{"floatIcon":"fa fa-navicon","level1Icon":"","level2Icon":"","level3Icon":"","showLevelIcon":false},"mode":"float","multipleH1":true,"pageTop":{"level1Icon":"","level2Icon":"","level3Icon":"","showLevelIcon":false},"printLog":false,"showGoTop":true,"showLevel":true},"favicon":{"shortcut":"assets/images/favicon.ico","bookmark":"assets/images/favicon.ico"},"theme-comscore":{},"local-video":{},"copy-code-button":{},"sharing":{"all":["facebook","google","twitter","weibo","instapaper"],"facebook":true,"google":false,"instapaper":false,"twitter":true,"vk":false,"weibo":false},"theme-default":{"styles":{"website":"styles/website.css","pdf":"styles/pdf.css","epub":"styles/epub.css","mobi":"styles/mobi.css","ebook":"styles/ebook.css","print":"styles/print.css"},"showLevel":false},"search-plus":{}},"theme":"default","author":"Aivin","pdf":{"pageNumbers":true,"fontSize":12,"fontFamily":"Arial","paperSize":"a4","chapterMark":"pagebreak","pageBreaksBefore":"/","margin":{"right":62,"left":62,"top":56,"bottom":56}},"structure":{"langs":"LANGS.md","readme":"README.md","glossary":"GLOSSARY.md","summary":"SUMMARY.md"},"variables":{},"title":"Aivin开发笔记","language":"zh-hans","gitbook":"*","description":"Aivin开发笔记"},"file":{"path":"chinese/web/ES6.md","mtime":"2018-10-31T06:09:59.586Z","type":"markdown"},"gitbook":{"version":"3.2.3","time":"2019-04-12T07:42:16.699Z"},"basePath":"../..","book":{"language":""}});
        });
    </script>
</div>

        
    <script src="../../gitbook/gitbook.js"></script>
    <script src="../../gitbook/theme.js"></script>
    
        
        <script src="../../gitbook/gitbook-plugin-search-plus/jquery.mark.min.js"></script>
        
    
        
        <script src="../../gitbook/gitbook-plugin-search-plus/search.js"></script>
        
    
        
        <script src="../../gitbook/gitbook-plugin-copy-code-button/toggle.js"></script>
        
    
        
        <script src="../../gitbook/gitbook-plugin-fontsettings/fontsettings.js"></script>
        
    
        
        <script src="../../gitbook/gitbook-plugin-donate/plugin.js"></script>
        
    
        
        <script src="../../gitbook/gitbook-plugin-local-video/video.min.js"></script>
        
    
        
        <script src="../../gitbook/gitbook-plugin-splitter/splitter.js"></script>
        
    
        
        <script src="../../gitbook/gitbook-plugin-lunr/lunr.min.js"></script>
        
    
        
        <script src="../../gitbook/gitbook-plugin-lunr/search-lunr.js"></script>
        
    
        
        <script src="../../gitbook/gitbook-plugin-sharing/buttons.js"></script>
        
    
        
        <script src="../../gitbook/gitbook-plugin-theme-comscore/test.js"></script>
        
    

    </body>
</html>

